#include <stdio.h>
#include<stdlib.h>
#include<string.h>
#include <windows.h>
typedef struct {
char Nom[20] ;
char Prenom [20];
int Note ;
}Etudiant;
typedef struct cellule {
Etudiant Etu ;
struct cellule * Next ;
}Cellule;
Etudiant Saisir()
{ Etudiant E;
printf("\n SAISI D'UN ETUDIANT : \n"); return E ;
}
void Afficher(Etudiant E)
{
printf(" Etudiant : %s %s %d \n",E.
Nom,E.
Prenom, E.
Note); }
void Add()
{ FILE * Fiche ;
char Nomf[20];
int cpt;
int Nbre; // Nbre d'etudiants a ajouter
Etudiant E ;
puts(" Nom de fichier à utiliser pour ajout ?"); puts(" Nbre d'etudiants a ajouter ?"); // Ouverture du fichier en ajout s'il existe sinon creation
Fiche
= fopen(Nomf
, "a+"); for(cpt=0 ; cpt<Nbre ;cpt++)
{
printf(" SAISI DE L'ELEVE %d : \n",cpt
+1); E = Saisir();
fwrite(&E
, sizeof(Etudiant
), 1 , Fiche
); }
}
void Load()
{ FILE * Fiche ;
char Nomf[20];
Etudiant E ;
puts(" Nom de fichier à Lire ?"); //Ouverture du fichier en lecture
Fiche
= fopen(Nomf
, "r"); if(Fiche==NULL)
{ puts(" Ce fichier n'existe pas !!!") ; return ;
}
while ( fread(&E
,sizeof(Etudiant
),1,Fiche
) !=0 ) {Afficher(E);
}
}
void SearchFirst()
{ FILE * Fiche ;
char Nomf[20];
char NomE[20];
int Found=0 ;
Etudiant E ;
puts(" Nom de fichier à Lire ?"); //Ouverture du fichier en lecture
Fiche
= fopen(Nomf
, "r"); if(Fiche==NULL)
{ puts(" Ce fichier n'existe pas !!!") ; return ;
}
puts(" Nom à rechercher ?"); while ( fread(&E
,sizeof(Etudiant
),1,Fiche
)!=0 && Found
==0) {
{
printf (" \n LA FICHE EST : \n"); Afficher(E);
Found=1;
}
}
if(Found==0)
printf("CET ETUDIANT N'EXISTE PAS !!!\n"); }
void Update()
{ FILE * Fiche ;
char Nomf[20];
char NomE[20]; // Nom de l'étudiant à rechercher
Etudiant E ;
puts(" Nom de fichier dans lequel on effectue la recherche ?"); puts(" Nom de l'étudiant à rechercher ?"); //Ouverture du fichier en lecture et autre
Fiche
= fopen(Nomf
, "r+"); if(Fiche==NULL)
{ puts(" Ce fichier n'existe pas !!!") ; return ;
}
while ( fread(&E
,sizeof(Etudiant
),1,Fiche
)!=0) { // Je recule de sizeof(Etudiant) octets
fseek(Fiche
, -sizeof(Etudiant
), SEEK_CUR
); puts(" Nouveau prenom "); printf(" La nouvelle note ?"); fwrite(&E
,sizeof(Etudiant
),1,Fiche
); return ;
}
}
printf("L'étudiant recherché n'existe pas !!!\n");
}
Etudiant* Upload(int * Nbre)
{ FILE * Fiche ;
char Nomf[20];
Etudiant * Liste ,E ;
int Nb=0 ;
puts(" Nom de fichier à charger ?"); // Ouverture du fichier en Lecture/Ecriture
Fiche
= fopen(Nomf
, "r+"); if(Fiche==NULL)
{ puts(" Ce fichier n'existe pas !!!") ; return NULL;
}
// On doit parcourir le fichier pour compter le nbre d'étudiants
while( fread(&E
,sizeof(Etudiant
),1, Fiche
) ) Nb++;
(*Nbre)=Nb ; // Mise a jour de la taille
// Allocation de l'espace nécessaire pour Nb étudiants
Liste
= (Etudiant
*) malloc(Nb
*sizeof(Etudiant
)); // Se repositionner au début
//je charge les Nb étudiants ds Liste
fread(Liste
, sizeof(Etudiant
), Nb
, Fiche
); // Mise à jour de nbre d'étudiants
return Liste ;
}
void Affichetable(Etudiant* Tab , int taille)
{
int i ;
puts(" LISTE DES ETUDIANTS "); for(i=0 ; i < taille ;i++)
{
Afficher(Tab[i]);
puts("===================================="); }
}
Cellule * Create(Etudiant E)
{
Cellule * Nouveau ;
Nouveau
= (Cellule
*) malloc(sizeof(Cellule
)); Nouveau->Etu = E ;
Nouveau->Next = NULL ;
return Nouveau ;
}
Cellule * AjoutDebut(Cellule *L,Etudiant E)
{ Cellule*p;
if(!L)
return Create(E);
p=Create(E);
p->Next=L;
return p;
}
Cellule * AjoutFin(Cellule *L , Etudiant E)
{ Cellule *p ;
if(!L)
return Create(E);
for(p=L ; p->Next!=NULL ; p=p->Next);
p->Next = Create(E);
return L ;
}
Cellule *DeleteFirst(Cellule *L)
{
if(!L)
return L->Next;
return NULL;
}
Cellule* UploadToList()
{ FILE * Fiche ;
char Nomf[20];
Cellule * Liste=NULL ;
Etudiant E ;
puts(" Nom de fichier à charger ?"); // Ouverture du fichier en Lecture
Fiche
= fopen(Nomf
, "r"); if(Fiche==NULL)
{ puts(" Ce fichier n'existe pas !!!") ; return NULL;
}
while( fread(&E
,sizeof(Etudiant
),1, Fiche
) ) {
Liste = AjoutFin(Liste, E);
}
return Liste ;
}
void AfficherListe(Cellule * L)
{
Cellule * p ;
if(!L)
{
puts(" LA LISTE EST VIDE "); return ;
}
puts(" LA LISTE CHAINEE DES ETUDIANTS EST "); for(p=L ; p; p=p->Next)
{
Afficher(p->Etu);
puts("======================================"); }
}
void StockerListe(Cellule * L)
{ FILE * Fiche ;
char Nomf[20];
Cellule * p ;
puts(" Nom de fichier à charger ?"); // Ouverture du fichier en ecriture
Fiche
= fopen(Nomf
, "w"); for(p=L ; p ; p=p->Next)
{
fwrite(&(p
->Etu
),sizeof(Etudiant
),1,Fiche
); }
}
void Delete()
{ Cellule* L=NULL, *p=NULL,*q=NULL ;
L= UploadToList();
char name[20];
puts(" Nom a supprimer"); if(L)
{
L= L->Next;
else // si name ne se trouve pas au debut
for(q
=L
, p
=L
->Next
; p
&& strcmp(p
->Etu.
Nom,name
)!=0 ; q
=p
, p
=p
->Next
); if(p!=NULL) // strcmp(p->Etu.Nom,name)==0
q->Next = p->Next;
else
puts(" Ce nom n'est pas dans la liste"); }
StockerListe(L);
}
Cellule * InsererCroissant( Cellule * L)
{ // On insere E dans la liste L triee croissante elle peut etre vide
Etudiant E ;
Cellule* Nouveau,*p,*q ;
E=Saisir();
Nouveau=Create(E);
if(!L)
return Nouveau;
if(strcmp(Nouveau
->Etu.
Nom,L
->Etu.
Nom)<=0) { Nouveau->Next = L;
return Nouveau;
}
// Ajoiut s'effectuera au dela de debut
for(q
=L
, p
=L
->Next
; p
&& strcmp(Nouveau
->Etu.
Nom,p
->Etu.
Nom)>0 ;q
=p
, p
=p
->Next
); // Point virgule /* for(q=L, p=L->Next ; p ;q=p , p=p->Next)
{
if (strcmp(Nouveau->Etu.Nom,p->Etu.Nom)<=0 ) break ;
}*/
q->Next = Nouveau;
Nouveau->Next = p ;
return L ;
}
Cellule * InsertCroissant( Cellule * L, Etudiant E)
{ // On insere E dans la liste L triee croissante elle peut etre vide
Cellule * Nouveau,*p,*q ;
Nouveau=Create(E);
if(!L)
return Nouveau;
if(strcmp(Nouveau
->Etu.
Nom,L
->Etu.
Nom)<=0) { Nouveau->Next = L;
return Nouveau;
}
// Ajouut s'effectuera au dela de debut
for(q
=L
, p
=L
->Next
; p
&& strcmp(Nouveau
->Etu.
Nom,p
->Etu.
Nom)>0 ;q
=p
, p
=p
->Next
); // Point virgule /* for(q=L, p=L->Next ; p ;q=p , p=p->Next)
{
if (strcmp(Nouveau->Etu.Nom,p->Etu.Nom)<=0 ) break ;
}*/
q->Next = Nouveau;
Nouveau->Next = p ;
return L ;
}
Cellule * InsertDecroissant(Cellule * L, Etudiant E)
{
Cellule * Nouveau,*p,*q ;
Nouveau=Create(E);
if(!L)
return Nouveau;
if(strcmp(Nouveau
->Etu.
Nom,L
->Etu.
Nom)>=0) {
Nouveau->Next=L;
return Nouveau;
}
for(q
=L
, p
=L
->Next
; p
&& strcmp(Nouveau
->Etu.
Nom,p
->Etu.
Nom)<0 ;q
=p
, p
=p
->Next
); q->Next = Nouveau;
Nouveau->Next = p ;
return L ;
}
Cellule* TriCroissant(Cellule * L)
{
Cellule *LT=NULL , *p=NULL;
for(p=L;p;p=p->Next)
{
LT=InsertCroissant(LT,p->Etu);
}
return LT;
}
Cellule * TriDecroissant(Cellule *L)
{
Cellule *LT=NULL , *p=NULL;
for(p=L;p;p=p->Next)
{
LT=InsertDecroissant(LT,p->Etu);
}
return LT;
}
Cellule *Renverser(Cellule * L)
{
Cellule *p, *q, *LI=NULL;
p=L;
while(p!=NULL) // a least there is a next
{
q=p->Next;
p->Next=LI;
LI=p;
p=q;
}
return LI;
}
int Taille(Cellule * L)
{
Cellule *p;
int i=0;
for(p=L,i=0;p;i++,p=p->Next);
return i;
}
Cellule * Position( Cellule *L, int pos)
{
int taille=Taille(L),i;
Cellule *p;
if(pos>taille)
return NULL;// Erreur
for(i=1 , p=L; i<pos ;i++ , p=p->Next);
return p;
}
Cellule* Creer() // Elle creee un seul etudiant
{
Cellule * Nouveau;
Nouveau
= (Cellule
*)malloc(sizeof(Cellule
)); Nouveau->Etu= Saisir();
Nouveau->Next=NULL;
return Nouveau;
}
// Cette fonction sert a inserer un etudiant dans une position precise si elle existe
Cellule * InsererPosition(Cellule *L,int pos)
{ int i ;
Cellule *p, *q, *Nouveau;
int taille=Taille(L); // la taille de la liste
if(pos<0 || pos>taille)
{
printf("la position %d n'existe pas \n",pos
); return L;
}
Nouveau=Creer(); // insertion
if(pos==1)
{
Nouveau->Next=L; // premiere cellule reservée pour le nouveau etudiant et le reste pour le reste de la liste
return Nouveau;
}
for(i=1,p=L;i<pos;i++,p=q,p=p->Next);
q->Next= Nouveau ;
Nouveau->Next=p;
return L ;
}
Cellule * ajouterAvantNom(Cellule * L,char tab[20])
{
Cellule *p, *q, *Nouveau;
Etudiant E;
Nouveau=Create(Saisir(E));
if (strcmp(L
->Etu.
Nom,tab
)==0) { Nouveau->Next=L;
return Nouveau;
}
for(p
=L
,q
=L
->Next
;q
&&strcmp(q
->Etu.
Nom,tab
)!=0;p
=q
,q
=q
->Next
); p->Next=Nouveau;
Nouveau->Next=q;
return L;
}
Cellule * ajouterApresNom(Cellule * L,char tab[20])
{
Cellule *p=NULL, *q=NULL, *Nouveau=NULL;
Etudiant E;
for(p
=L
,q
=p
->Next
;q
&&strcmp(p
->Etu.
Nom,tab
)!=0;p
=q
,q
=q
->Next
); Nouveau=Create(Saisir(E));
p->Next=Nouveau;
Nouveau->Next=q;
return L;
}
int Menu()
{ int choix ;
printf("\n 1----> Ajout Debut \n"); printf(" 2 ----> Ajout Fin: \n"); printf(" 3 ----> Ajout Avant un nom \n"); printf(" 4 ----> Ajout Après un nom \n"); printf(" 5 ----> DeleteFirst \n"); printf(" 6 ----> DeleteAll \n"); printf(" 7 ----> Afficher Liste \n"); printf(" 8 ----> Le nom d'une position \n"); printf(" 9 ----> Ajout d'un nom dans une position \n"); printf(" 10 ----> Inserer Croissant \n"); printf(" 11 ----> Tri Croissant \n"); printf(" 12 ----> Tri DeCroissant \n"); printf(" 13 ----> Renverser \n"); printf(" 14 ----> Le nom d'une position \n"); return choix ;
}
int main()
{ Cellule *GINF1=NULL, *Res;
int b;
Etudiant E;
char nom[20];
int choix, pos;
do
{
choix=Menu();
switch (choix) {
case 1:
E=Saisir();
GINF1=AjoutDebut(GINF1,E);
break;
case 2:
E=Saisir();
GINF1=AjoutFin(GINF1,E);
break;
case 3:
printf("le nom Avant lequel on va ajouter\n"); GINF1=ajouterAvantNom(GINF1,nom);
break;
case 4:
printf("le nom apres lequel on va ajouter\n"); GINF1=ajouterApresNom(GINF1,nom);
break;
case 5:
GINF1=DeleteFirst(GINF1);
break;
case 6:
GINF1=NULL;
break;
case 7:
AfficherListe(GINF1);
break;
case 8:
Res= Position(GINF1,pos);
if(Res!=NULL)
{
Afficher(Res->Etu);
}else
{
puts("ceci n'existe pas"); }
break;
case 9:
printf("La position s'il vois plait \n"); Res=Position(GINF1,pos);
if(Res!=NULL)
{
InsererPosition(Res,pos);
}else
{
puts("ceci n'existe pas"); }
break;
case 10:
GINF1=InsererCroissant(GINF1);
break;
case 11:
GINF1=TriCroissant(GINF1);
break;
case 12:
GINF1=TriDecroissant(GINF1);
break;
case 13:
GINF1=Renverser(GINF1);
break;
default :
printf("ce chois n est pas valide\n"); break;
}
printf("voulez vous continuer ??\n1.oui 2.non\n Choix : "); }while(b!=2);
return 0 ;
}
#include <stdio.h>
#include<stdlib.h>
#include<string.h>
#include <windows.h>
typedef struct {
    char Nom[20] ;
    char Prenom [20];
    int Note ;
}Etudiant;
typedef struct cellule {
    Etudiant Etu ;
    struct cellule * Next ;
}Cellule;
Etudiant Saisir()
{  Etudiant E;
    printf("\n SAISI D'UN ETUDIANT : \n");
    printf(" Nom : ");
    scanf("%s",E.Nom);
    printf(" Prénom : ");
    scanf("%s",E.Prenom);
    printf(" Note : ");
    scanf("%d",&(E.Note));
    return E ;
}
void Afficher(Etudiant E)
{
    printf(" Etudiant : %s   %s   %d \n",E.Nom,E.Prenom, E.Note);
}
void Add()
{  FILE * Fiche ;
    char Nomf[20];
    int cpt;
    int Nbre; // Nbre d'etudiants a ajouter
    Etudiant E ;
    puts(" Nom de fichier à utiliser pour ajout ?");
    scanf("%s",Nomf);
    puts(" Nbre d'etudiants a ajouter ?");
    scanf("%d",&Nbre);
    // Ouverture du fichier en ajout s'il existe sinon creation
    Fiche = fopen(Nomf , "a+");
    for(cpt=0 ; cpt<Nbre ;cpt++)
    {
        printf(" SAISI DE L'ELEVE %d : \n",cpt+1);
        E = Saisir();
        fwrite(&E , sizeof(Etudiant), 1 , Fiche);
    }
    fclose(Fiche);
}
void Load()
{   FILE * Fiche ;
    char Nomf[20];
    Etudiant E ;
    puts(" Nom de fichier à Lire ?");
    scanf("%s",Nomf);
    //Ouverture du fichier en lecture
    Fiche = fopen(Nomf , "r");
    if(Fiche==NULL)
    { puts(" Ce fichier n'existe pas !!!") ;
        return ;
    }
    while ( fread(&E,sizeof(Etudiant),1,Fiche) !=0 )
    {Afficher(E);
    }
    fclose(Fiche);
}
void SearchFirst()
{   FILE * Fiche ;
    char Nomf[20];
    char NomE[20];
    int Found=0 ;
    Etudiant E ;
    puts(" Nom de fichier à Lire ?");
    scanf("%s",Nomf);
    //Ouverture du fichier en lecture
    Fiche = fopen(Nomf , "r");
    if(Fiche==NULL)
    {   puts(" Ce fichier n'existe pas !!!") ;
        return ;
    }
    puts(" Nom à rechercher ?");
    scanf("%s",NomE);
    while ( fread(&E,sizeof(Etudiant),1,Fiche)!=0 && Found==0)
    {
        if(strcmp(E.Nom,NomE)==0)
        {
            printf (" \n LA FICHE EST : \n");
            Afficher(E);
            Found=1;
        }

    }
    if(Found==0)
        printf("CET ETUDIANT N'EXISTE PAS !!!\n");
    fclose(Fiche);
}
void Update()
{   FILE * Fiche ;
    char Nomf[20];
    char NomE[20]; // Nom de l'étudiant à rechercher
    Etudiant E ;
    puts(" Nom de fichier dans lequel on effectue la recherche  ?");
    scanf("%s",Nomf);
    puts(" Nom de l'étudiant à rechercher ?");
    scanf("%s",NomE);
    //Ouverture du fichier en lecture et autre
    Fiche = fopen(Nomf , "r+");
    if(Fiche==NULL)
    {   puts(" Ce fichier n'existe pas !!!") ;
        return ;
    }
    while ( fread(&E,sizeof(Etudiant),1,Fiche)!=0)
    {        if(strcmp(E.Nom,NomE)== 0 )
    {  // Je recule de sizeof(Etudiant) octets
        fseek(Fiche, -sizeof(Etudiant), SEEK_CUR);
        puts(" Nouveau prenom ");
        printf(" Prenom : ");
        scanf("%s",E.Prenom);
        printf(" La nouvelle note ?");
        scanf("%d",&(E.Note));
        fwrite(&E,sizeof(Etudiant),1,Fiche);
        printf(" Update ok  ");
        fclose(Fiche);
        return ;
    }
    }


    printf("L'étudiant recherché n'existe pas !!!\n");
    fclose(Fiche);

}
 Etudiant* Upload(int * Nbre)
{    FILE * Fiche ;
    char Nomf[20];
    Etudiant * Liste ,E ;
    int Nb=0 ;
    puts(" Nom de fichier à charger   ?");
    scanf("%s",Nomf);
    // Ouverture du fichier en Lecture/Ecriture
    Fiche = fopen(Nomf, "r+");
    if(Fiche==NULL)
    {   puts(" Ce fichier n'existe pas !!!") ;
        return NULL;
    }
    // On doit parcourir le fichier pour compter le nbre d'étudiants
    while( fread(&E,sizeof(Etudiant),1, Fiche) )
        Nb++;
    (*Nbre)=Nb ; // Mise a jour de la taille
    // Allocation de l'espace nécessaire pour Nb étudiants
    Liste = (Etudiant*) malloc(Nb*sizeof(Etudiant));
    // Se repositionner au début
    rewind(Fiche);
    //je charge les Nb étudiants ds Liste
    fread(Liste , sizeof(Etudiant), Nb , Fiche);
    // Mise à jour de nbre d'étudiants

    fclose(Fiche);
    return Liste ;

}
void Affichetable(Etudiant* Tab , int taille)
{
    int i ;
    puts(" LISTE DES ETUDIANTS ");
    for(i=0 ; i < taille ;i++)
    {
        Afficher(Tab[i]);
        puts("====================================");
    }
}
Cellule * Create(Etudiant E)
{
    Cellule * Nouveau ;
    Nouveau = (Cellule*) malloc(sizeof(Cellule));
    Nouveau->Etu = E ;
    Nouveau->Next = NULL ;
    return Nouveau ;
}
Cellule * AjoutDebut(Cellule *L,Etudiant E)
{ Cellule*p;
  if(!L)
      return Create(E);
  p=Create(E);
  p->Next=L;
  return p;
}
Cellule * AjoutFin(Cellule *L , Etudiant E)
{ Cellule *p ;
    if(!L)
        return Create(E);
    for(p=L ; p->Next!=NULL ; p=p->Next);
    p->Next = Create(E);
    return L ;
}

Cellule *DeleteFirst(Cellule *L)
{
  if(!L)
   return L->Next;
  printf("liste VIDE");
  return NULL;
}
Cellule* UploadToList()
{    FILE * Fiche ;
    char Nomf[20];
    Cellule * Liste=NULL ;
    Etudiant E ;
    puts(" Nom de fichier à charger   ?");
    scanf("%s",Nomf);
    // Ouverture du fichier en Lecture
    Fiche = fopen(Nomf, "r");
    if(Fiche==NULL)
    {   puts(" Ce fichier n'existe pas !!!") ;
        return NULL;
    }
fseek
    while( fread(&E,sizeof(Etudiant),1, Fiche) )
    {
        Liste = AjoutFin(Liste, E);
    }

    fclose(Fiche);
    return Liste ;

}

void AfficherListe(Cellule * L)
{
    Cellule * p ;
    if(!L)
    {
        puts(" LA LISTE EST VIDE ");
        return ;
    }
    puts(" LA LISTE CHAINEE DES ETUDIANTS EST ");
    for(p=L ; p; p=p->Next)
    {
        Afficher(p->Etu);
        puts("======================================");
    }
}
void StockerListe(Cellule * L)
{    FILE * Fiche ;
     char Nomf[20];
    Cellule * p ;
    puts(" Nom de fichier à charger   ?");
    scanf("%s",Nomf);
    // Ouverture du fichier en ecriture
    Fiche = fopen(Nomf, "w");
    for(p=L ; p ; p=p->Next)
    {
        fwrite(&(p->Etu),sizeof(Etudiant),1,Fiche);
    }
    fclose(Fiche);
}
void Delete()
{  Cellule* L=NULL, *p=NULL,*q=NULL ;
    L= UploadToList();
    char name[20];
    puts(" Nom a supprimer");
    scanf("%s",name);
    if(L)
    {
        if(!strcmp(L->Etu.Nom,name) )
           L= L->Next;
        else // si name ne se trouve pas au debut
   for(q=L , p=L->Next ; p && strcmp(p->Etu.Nom,name)!=0 ; q=p , p=p->Next);
     if(p!=NULL) // strcmp(p->Etu.Nom,name)==0
         q->Next = p->Next;
    else
        puts(" Ce nom n'est pas dans la liste");
    }
    StockerListe(L);

}
Cellule * InsererCroissant( Cellule * L)
{ // On insere E dans la liste L triee croissante elle peut etre vide
    Etudiant E ;
    Cellule* Nouveau,*p,*q ;
    E=Saisir();
    Nouveau=Create(E);
    if(!L)
        return Nouveau;

    if(strcmp(Nouveau->Etu.Nom,L->Etu.Nom)<=0)
    { Nouveau->Next = L;
        return Nouveau;
    }
    // Ajoiut s'effectuera au dela de debut
 for(q=L, p=L->Next ; p && strcmp(Nouveau->Etu.Nom,p->Etu.Nom)>0 ;q=p , p=p->Next); // Point virgule
    /* for(q=L, p=L->Next ; p ;q=p , p=p->Next)
     {
         if (strcmp(Nouveau->Etu.Nom,p->Etu.Nom)<=0 ) break ;
     }*/
    q->Next = Nouveau;
    Nouveau->Next = p ;
    return L ;
}

Cellule * InsertCroissant( Cellule * L, Etudiant  E)
{ // On insere E dans la liste L triee croissante elle peut etre vide
    Cellule * Nouveau,*p,*q ;
    Nouveau=Create(E);
    if(!L)
        return Nouveau;

    if(strcmp(Nouveau->Etu.Nom,L->Etu.Nom)<=0)
    { Nouveau->Next = L;
        return Nouveau;
    }
    // Ajouut s'effectuera au dela de debut
 for(q=L, p=L->Next ; p && strcmp(Nouveau->Etu.Nom,p->Etu.Nom)>0 ;q=p , p=p->Next); // Point virgule
    /* for(q=L, p=L->Next ; p ;q=p , p=p->Next)
     {
         if (strcmp(Nouveau->Etu.Nom,p->Etu.Nom)<=0 ) break ;
     }*/
    q->Next = Nouveau;
    Nouveau->Next = p ;
    return L ;
}


Cellule * InsertDecroissant(Cellule * L, Etudiant  E)
{
  Cellule * Nouveau,*p,*q ;
  Nouveau=Create(E);
  if(!L)
      return Nouveau;

  if(strcmp(Nouveau->Etu.Nom,L->Etu.Nom)>=0)
  {
      Nouveau->Next=L;
      return Nouveau;
  }
for(q=L, p=L->Next ; p && strcmp(Nouveau->Etu.Nom,p->Etu.Nom)<0 ;q=p , p=p->Next);
  q->Next = Nouveau;
  Nouveau->Next = p ;
  return L ;
}


Cellule* TriCroissant(Cellule * L)
  {
    Cellule *LT=NULL , *p=NULL;
    for(p=L;p;p=p->Next)
    {
      LT=InsertCroissant(LT,p->Etu);
    }
    return LT;
  }
Cellule * TriDecroissant(Cellule *L)
{
  Cellule *LT=NULL , *p=NULL;
  for(p=L;p;p=p->Next)
  {
    LT=InsertDecroissant(LT,p->Etu);
  }
  return LT;
}
Cellule *Renverser(Cellule * L)
{
  Cellule *p, *q, *LI=NULL;
  p=L;
  while(p!=NULL) // a least there is a next
  {
    q=p->Next;
    p->Next=LI;
    LI=p;
    p=q;
  }
  return LI;
}
int   Taille(Cellule * L)
{
  Cellule *p;
  int i=0;
  for(p=L,i=0;p;i++,p=p->Next);
  return i;
}

Cellule * Position( Cellule *L, int pos)
{
  int taille=Taille(L),i;
  Cellule *p;
  if(pos>taille)
  return NULL;// Erreur
  for(i=1 , p=L; i<pos ;i++ , p=p->Next);
  return p;
}
Cellule* Creer()  // Elle creee un seul etudiant
{
  Cellule * Nouveau;
  Nouveau = (Cellule*)malloc(sizeof(Cellule));
  Nouveau->Etu= Saisir();
  Nouveau->Next=NULL;
  return Nouveau;
}
// Cette fonction sert a inserer un etudiant dans une position precise si elle existe
Cellule * InsererPosition(Cellule *L,int pos)
{ int i ;
  Cellule *p, *q, *Nouveau;
  int taille=Taille(L); // la taille de la liste
  if(pos<0 || pos>taille)
  {
    printf("la position %d n'existe pas \n",pos );
    return L;
  }
  Nouveau=Creer(); // insertion
  if(pos==1)
  {
    Nouveau->Next=L; // premiere cellule reservée pour le nouveau etudiant et le reste pour le reste de la liste
    return Nouveau;
  }
  for(i=1,p=L;i<pos;i++,p=q,p=p->Next);
  q->Next= Nouveau ;
  Nouveau->Next=p;
  return L ;

}
Cellule * ajouterAvantNom(Cellule * L,char tab[20])
{
  Cellule *p, *q, *Nouveau;
  Etudiant E;
  Nouveau=Create(Saisir(E));
  if (strcmp(L->Etu.Nom,tab)==0) {
    Nouveau->Next=L;
    return Nouveau;
  }
  for(p=L,q=L->Next;q&&strcmp(q->Etu.Nom,tab)!=0;p=q,q=q->Next);
  p->Next=Nouveau;
  Nouveau->Next=q;
  return L;
}

Cellule * ajouterApresNom(Cellule * L,char tab[20])
{
  Cellule *p=NULL, *q=NULL, *Nouveau=NULL;
  Etudiant E;
  for(p=L,q=p->Next;q&&strcmp(p->Etu.Nom,tab)!=0;p=q,q=q->Next);
  Nouveau=Create(Saisir(E));
  p->Next=Nouveau;
  Nouveau->Next=q;
  return L;
}

int Menu()
{   int choix ;
    printf("\n    1---->    Ajout Debut    \n");
    printf("    2 ---->   Ajout Fin: \n");
    printf("    3 ---->   Ajout  Avant un nom    \n");
    printf("    4 ---->   Ajout  Après un nom   \n");
    printf("    5 ---->   DeleteFirst \n");
    printf("    6 ---->   DeleteAll \n");
    printf("    7 ---->   Afficher Liste \n");
    printf("    8 ---->   Le nom d'une position \n");
    printf("    9 ---->   Ajout d'un nom dans une position \n");
    printf("   10 ---->   Inserer Croissant \n");
    printf("   11 ---->   Tri Croissant \n");
    printf("   12 ---->   Tri DeCroissant \n");
    printf("   13 ---->   Renverser \n");
    printf("   14 ---->   Le nom d'une position \n");
    scanf("%d",&choix);
    return choix ;
}
int main()
{  Cellule *GINF1=NULL, *Res;
  int b;
  Etudiant E;
  char nom[20];
  int choix, pos;
  do
  {
    system("cls");
    choix=Menu();
    switch (choix) {
      case 1:
              E=Saisir();
              GINF1=AjoutDebut(GINF1,E);
              break;
      case 2:
              E=Saisir();
              GINF1=AjoutFin(GINF1,E);
              break;
      case 3:
              printf("le nom Avant lequel on va ajouter\n");
              scanf("%s",nom);
              GINF1=ajouterAvantNom(GINF1,nom);
              break;
      case 4:
              printf("le nom apres lequel on va ajouter\n");
              scanf("%s",nom);
              GINF1=ajouterApresNom(GINF1,nom);
              break;
      case 5:
              GINF1=DeleteFirst(GINF1);
              break;
      case 6:
              GINF1=NULL;
              break;
      case 7:
              AfficherListe(GINF1);
              break;
      case 8:
              printf("la postiton svp\n");
              scanf("%d\n",&pos );
              Res= Position(GINF1,pos);
                if(Res!=NULL)
                {
                  Afficher(Res->Etu);
                }else
                {
                  puts("ceci n'existe pas");
                }
              break;

      case 9:
              printf("La position s'il vois plait \n");
              scanf("%d\n",pos );
              Res=Position(GINF1,pos);
              if(Res!=NULL)
              {
                InsererPosition(Res,pos);
              }else
              {
                puts("ceci n'existe pas");
              }
              break;
      case 10:
              GINF1=InsererCroissant(GINF1);
              break;
      case 11:
              GINF1=TriCroissant(GINF1);
              break;
      case 12:
              GINF1=TriDecroissant(GINF1);
              break;
      case 13:
              GINF1=Renverser(GINF1);
              break;
      default :
                printf("ce chois n est pas valide\n");
                break;
    }
    printf("voulez vous continuer ??\n1.oui   2.non\n Choix : ");
    scanf("%d",&b);
  }while(b!=2);
    return 0 ;
}
