1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
|
void inserer(cellule **l ,type elmt,int index)
{
int i=0;
cellule *nv=NULL,*p=NULL;
nv=malloc(sizeof(cellule));
if (index<0)
{
printf("L'index doit etre superieur ou egal a 0\n,ARRET DU PROGRAMME\n");
exit(EXIT_FAILURE);
}
if (index==0)
{
ajoutertete(l,elmt);//ajoute l'element a la tete de la liste
}
if (index == taille(*l))//taille retourne la taille de la liste
{
ajouterfin(l,elmt); // la tu ajoute l'element dans la liste taille est augmenté de 1
}
if (index>0 && index <taille(*l)) // du coup index devient < taille
{
// et donc tu le rajoutes une 2eme fois
p=*l;
while(p!=NULL && i!=index)
{
i++;
p=p->suiv;
}
nv->suiv=p->suiv;
p->suiv=nv;
nv->data=elmt;
}
// Cette condition ne sert à rien
if (index==taille(*l))
{
ajouterfin(l,elmt);//ajoute l'element a la fin de la liste
}
if (index>taille(*l))
{
printf("Position inexistante ARRET DU PROGRAMME EN COURS\n");
exit(EXIT_FAILURE);
}
} |
Partager