Forum |  HardWare.fr | News | Articles | PC | S'identifier | S'inscrire | Shop Recherche
1582 connectés 

  FORUM HardWare.fr
  Programmation
  C++

  [C / Algo] - Tri d'une liste chainée par nom [ résolu... oufff ! ]

 


 Mot :   Pseudo :  
 
 Page :   1  2
Page Précédente
Auteur Sujet :

[C / Algo] - Tri d'une liste chainée par nom [ résolu... oufff ! ]

n°266367
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 14:10:00  profilanswer
 

Bonjour,  
 
ca fait des jours que j'essaie de trouver une solution, mais c'est trop pour moi j'y arrive pas :'( ...
 
voila j'ai une liste chainees avec des maillons de ce type :  
 

Code :
  1. struct DATA
  2. {
  3.    char nom[31];
  4.    char prenom[21];
  5.    char telephone[16];
  6.    char adresse[51];
  7.    char cp[5];
  8.    char ville[31];
  9.    char metier[31];
  10.    struct DATA *pSuivant;
  11.    struct DATA *pPrecedent;
  12. };


 
non triée biensur,  
 
Si qqun pouvais m'aider a faire un algo pour trié cette sdfsdffsd de liste chainee par ordre de nom ascendant :/ ca serait super cool, parce qeu la je m'emmele les pinceau et je dois remettre mon projet cette semaine  :cry:  
 
Merci d'avance :( pour votre aide


Message édité par _maximus_ le 12-12-2002 à 02:21:16

---------------
Ptit con de goret je t'emmerde ^_^
mood
Publicité
Posté le 10-12-2002 à 14:10:00  profilanswer
 

n°266397
bjone
Insert booze to continue
Posté le 10-12-2002 à 14:38:19  profilanswer
 

bin tu peux faire un tri à bulle (version avec sélection ou je sais plus comment), du style:
 
pour i du premier à l'avant dernier
 
  m <- rien de mieux
 
  pour j du suivant de i au dernier
      si j est "<" à i
        m <- j
      fin si
  fin pour
 
  si m n'est pas "rien de mieux"
    injecter m avant i
  fin si
 
fin pour
 
voilà, démerdes toa avec ça :D

n°266407
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 14:45:32  profilanswer
 

bjone a écrit :

bin tu peux faire un tri à bulle (version avec sélection ou je sais plus comment), du style:
 
pour i du premier à l'avant dernier
 
  m <- rien de mieux
 
  pour j du suivant de i au dernier
      si j est "<" à i
        m <- j
      fin si
  fin pour
 
  si m n'est pas "rien de mieux"
    injecter m avant i
  fin si
 
fin pour
 
voilà, démerdes toa avec ça :D


 
Salut,  
 
mais dans ma liste chainée, il n'y a pas d'indice, dois-je tout remettre dans un tableau normal avant de proceder au tri a bulle??  
 
aussi j'ai pas compris ce que signifie le "rien de mieux"  :??:  
 
merci


---------------
Ptit con de goret je t'emmerde ^_^
n°266409
antp
Super Administrateur
Champion des excuses bidons
Posté le 10-12-2002 à 14:47:57  profilanswer
 

spa plus simple d'utiliser qsort ?


---------------
mes programmes ·· les voitures dans les films ·· apprenez à écrire
n°266411
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 14:49:54  profilanswer
 

antp a écrit :

spa plus simple d'utiliser qsort ?


 
J'avais trouvé cette fonction qsort, mais je dois avouer que j'ai rien capté a son utilisation :'(
y a moyen de trier DIRECTEMENT une liste chainées du type que je viens de donné avec ca?  
 
Le principe serait d'echanger les adresse de pSuivant et pPrecedent de la structure pour trier la liste chainee...  
 :pt1cable:


---------------
Ptit con de goret je t'emmerde ^_^
n°266414
bjone
Insert booze to continue
Posté le 10-12-2002 à 14:52:18  profilanswer
 

_Maximus_ a écrit :


 
Salut,  
 
mais dans ma liste chainée, il n'y a pas d'indice, dois-je tout remettre dans un tableau normal avant de proceder au tri a bulle??  
 
aussi j'ai pas compris ce que signifie le "rien de mieux"  :??:  
 
merci


 
i peut être un pointeur :D

n°266416
antp
Super Administrateur
Champion des excuses bidons
Posté le 10-12-2002 à 14:53:07  profilanswer
 

je sais plus si ça marche avec les listes chaînées en fait... ça date d'y a longtemps pour moi ces trucs-là :D


---------------
mes programmes ·· les voitures dans les films ·· apprenez à écrire
n°266417
bjone
Insert booze to continue
Posté le 10-12-2002 à 14:54:03  profilanswer
 

qsort ça implique un tableau d'objets (linéaire)

n°266421
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 14:57:11  profilanswer
 

bjone a écrit :


 
i peut être un pointeur :D


 
ok mais je vois vraiment pasdu tout comment faire.... :(


---------------
Ptit con de goret je t'emmerde ^_^
n°266424
bjone
Insert booze to continue
Posté le 10-12-2002 à 14:59:18  profilanswer
 

bin j'ai déjà fait 40% de ton taf....

mood
Publicité
Posté le 10-12-2002 à 14:59:18  profilanswer
 

n°266425
bjone
Insert booze to continue
Posté le 10-12-2002 à 15:01:52  profilanswer
 

bon aide:
 
les "pour" se traduiront certainement en parcours via le "suivant" de chaque élément de la liste chainée.
 
beaucoup de variables seront des pointeurs.
 
l'injection aura ptet des cas particulier à prendre en compte.

n°266426
darkoli
Le Petit Dinosaure Bleu
Posté le 10-12-2002 à 15:02:42  profilanswer
 

_Maximus_ a écrit :


 
J'avais trouvé cette fonction qsort, mais je dois avouer que j'ai rien capté a son utilisation :'(
y a moyen de trier DIRECTEMENT une liste chainées du type que je viens de donné avec ca?  
 
Le principe serait d'echanger les adresse de pSuivant et pPrecedent de la structure pour trier la liste chainee...  
 :pt1cable:  


Ben déjà tu fais une fonction magique qui gère l'inversion de deux maillons de ta liste. Simplement en lui filant en paramètre les deux adresses. Vu que ta liste est doublement chaînée c'est nickel y'a rien d'autre à faire.
 
Ensuite tu pourras te concentrer sur le tri de ta liste ...


---------------
Le site de l'année :D (XHTML 1.0 strict) : http://darkoli.free.fr/index.html
n°266428
Carbon_14
Posté le 10-12-2002 à 15:03:46  profilanswer
 

Dans la méthode bjone, le i et le j correspondent au rang des "enregistrements" dans la "base de données".
Y a bien un premier, un second objet entré ? puis un troisième, etc..
 
Faut appliquer son algo en mettant à jour les *pSuivant et *pPrecedent à chaque comparaison.
 
En faisant le truc avec un exemple sur une feuille de papier, ça permet de voir le principe, ensuite la machine le fera pour le fichier une fois mis au point. :)

n°266430
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 15:04:49  profilanswer
 

bjone a écrit :

bon aide:
 
les "pour" se traduiront certainement en parcours via le "suivant" de chaque élément de la liste chainée.
 
beaucoup de variables seront des pointeurs.
 
l'injection aura ptet des cas particulier à prendre en compte.


 
Merci j'avais compris pour les pour, la je suis occupé a essayer de le faire en C, ùmais je n'ai pas compris comment traduire ca "m <- rien de mieux"
ca fait quoi exactement? Merci


---------------
Ptit con de goret je t'emmerde ^_^
n°266432
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 15:06:47  profilanswer
 

carbon_14 a écrit :

Dans la méthode bjone, le i et le j correspondent au rang des "enregistrements" dans la "base de données".
Y a bien un premier, un second objet entré ? puis un troisième, etc..
 
Faut appliquer son algo en mettant à jour les *pSuivant et *pPrecedent à chaque comparaison.
 
En faisant le truc avec un exemple sur une feuille de papier, ça permet de voir le principe, ensuite la machine le fera pour le fichier une fois mis au point. :)  


 
Yep je commence a y voir plus clair, mais chui pas encore sur du tout de ce que je fais, quand j'aurai fait l'algo je le posterai ( je suppose kil foirera au premier coup :/ )  
 


---------------
Ptit con de goret je t'emmerde ^_^
n°266435
bjone
Insert booze to continue
Posté le 10-12-2002 à 15:09:48  profilanswer
 

en fait:
 
faire les échanges d'éléments via les pointeurs  
suivant/précédent à chaque fois c'est du pure tri à bulle (ou à plomb :D)
 
mais si tu maintiens l'élement qui est plus "petit" (ou plus "grand" ), tu as juste à balayer tous les éléments suivant le courant, et faire un échange d'élements à la fin une fois que tu sais kicékiestmieuxplacé, c'est du tri par sélection/insertion (en principe plus rapide).
 
en gros ce que j'ai donné c'est:
 
pour chaque élement sauf le dernier
     pour chaque élement à partir du "suivant du courant"
          si l'élement il me plait mieux je le "mémorise"
     fin pour
     
     si il y a un élément qui me plait mieux
          je le DEPLACE devant le  courant
     fin si
fin pour


Message édité par bjone le 10-12-2002 à 15:11:14
n°266437
bjone
Insert booze to continue
Posté le 10-12-2002 à 15:10:32  profilanswer
 

peux pas faire plus simple.

n°266439
bjone
Insert booze to continue
Posté le 10-12-2002 à 15:12:12  profilanswer
 

a oui en fait y'aura un problème :D
 
dans le:
 
si il y a un élément qui me plait mieux  
    je le DEPLACE devant le courant  
fin si  
 
faut faire attention à repartir du courant (et pas du meilleur élément déplacé ou du suivant du courant ) à la prochaine itération générale.


Message édité par bjone le 10-12-2002 à 15:14:26
n°266441
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 15:13:59  profilanswer
 

bjone a écrit :

peux pas faire plus simple.


Si j'ai bien capté, ton M c'est le courant c ca?


---------------
Ptit con de goret je t'emmerde ^_^
n°266442
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 15:14:17  profilanswer
 

bjone a écrit :

a oui en fait y'aura un problème :D


 
cad?  :??:  


---------------
Ptit con de goret je t'emmerde ^_^
n°266443
bjone
Insert booze to continue
Posté le 10-12-2002 à 15:16:06  profilanswer
 

dans le truc initial:
 
i -> le courant
j -> permet de balayer du suivant du courant au dernier
m -> élément à insérer devant i

n°266444
bjone
Insert booze to continue
Posté le 10-12-2002 à 15:22:26  profilanswer
 

honte à moi, le vilain bug que je te fait faire:
 
pour i du premier à l'avant dernier  
 
 m <- i
 
 pour j du suivant de i au dernier  
     si j est "<" à m  
       m <- j  
     fin si  
 fin pour  
 
 si m est différent de i
   injecter m avant i  
 fin si  
 
fin pour  

n°266446
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 15:23:37  profilanswer
 

bjone a écrit :

honte à moi, le vilain bug que je te fait faire:
 
pour i du premier à l'avant dernier  
 
 m <- i
 
 pour j du suivant de i au dernier  
     si j est "<" à m  
       m <- j  
     fin si  
 fin pour  
 
 si m est différent de i
   injecter m avant i  
 fin si  
 
fin pour  
 


 
lol s'pas grave,  
 
bon je v essayer avec ca... des que c fini je poste mon code
tkx


---------------
Ptit con de goret je t'emmerde ^_^
n°266458
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 15:39:26  profilanswer
 

Bon voila ce que donne le code de ma fonction mais comme prevu ca foire  :D , j'ai du loupé qque chose, en fait quand j'affiche ma liste chainee apres ca, non seulement c pas trié mais en plus il manque plein de maillon ... qu'est ce qeu j'ai encore foutu moi...  
 
 

Code :
  1. void TriNom(struct DATA *LC_result)
  2. {
  3.    struct DATA *pMem, *pTmp, *pI, *pJ;
  4.    pI=LC_result;
  5.    while(pI->pSuivant->pSuivant!=NULL)
  6.    {
  7.       pMem=pI;
  8.       pJ=pI->pSuivant;
  9.       while(pJ->pSuivant!=NULL)
  10.       {
  11.        if(strcmp(pJ->nom, pMem->nom)<0)
  12.          {
  13.      pMem=pJ;
  14.          }
  15.          pJ=pJ->pSuivant;
  16.       }
  17.       if(strcmp(pMem, pI)!=0)
  18.       {
  19.          pTmp=pMem->pSuivant;
  20.        pMem->pSuivant=pI;
  21.          pI->pSuivant=pTmp;
  22.       }
  23.     pI=pI->pSuivant;
  24.    }
  25. }


Message édité par _maximus_ le 10-12-2002 à 15:40:04

---------------
Ptit con de goret je t'emmerde ^_^
n°266475
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 15:57:37  profilanswer
 

bon jai corrigé ce qu'il y avait dans la derniere conditrion c t pas bon, mais ca marche tjrs pas :/  
 

Code :
  1. void TriNom(struct DATA *LC_result)
  2. {
  3.    struct DATA *pMem, *pTmp, *pI, *pJ;
  4.    pI=LC_result;
  5.    while(pI->pSuivant->pSuivant!=NULL)
  6.    {
  7.  pMem=pI;
  8.       pJ=pI->pSuivant;
  9.       while(pJ->pSuivant!=NULL)
  10.       {
  11.        if(strcmp(pJ->nom, pMem->nom)<0)
  12.          {
  13.    pMem=pJ;
  14.          }
  15.          pJ=pJ->pSuivant;
  16.       }
  17.       if(strcmp(pMem, pI)!=0)
  18.       {
  19.          pI->pSuivant=pMem->pSuivant;
  20.          pMem->pSuivant=pI;
  21.       }
  22.     pI=pI->pSuivant;
  23.    }
  24. }


---------------
Ptit con de goret je t'emmerde ^_^
n°266493
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 16:17:21  profilanswer
 

Mon code vous fait peur? Zetes tous parti? :'(  
 
help plz m'en sort plus je test pas a pas mon code avec des printf partout, je vois pas ce qui cloche si la logique est bonne :(
 
 :cry:


---------------
Ptit con de goret je t'emmerde ^_^
n°266496
bjone
Insert booze to continue
Posté le 10-12-2002 à 16:21:30  profilanswer
 

alors dans le while, il faut:
 
while( pI->pSuivant != NULL && pI->pSuivant->pSuivant!=NULL )
 
qui est équivalent à:
 
while( pI->pSuivant && pI->pSuivant->pSuivant )
 
et encore par sécurité:
 
while( pI && pI->psuivant....
 
ça protège des bugs plus bas, et ça protège du cas ou il y a q'un seul élément....
 
pour le if:
 
if(strcmp(pMem, pI)!=0)
            {
                 pI->pSuivant=pMem->pSuivant;
                 pMem->pSuivant=pI;
         
}
 
vo mieux:
 
if( pMem != pI )
{
   
}
 
ensuite ton insertion est "fausse" :D
 
ton insertion doit faire:
 
// meilleur devant courant
courant->précédent->suivant = meilleur
courant->précédent = meilleur
 
// on "enlève" meilleur
meilleur->précédent->suivant = meilleur->suivant
meilleur->suivant->précédent = meilleur->précédent
 
// meilleur devant courant (suite)
meilleur->suivant=courant
 
et ceci doit gérer les cas spéciaux:
 
insetion devant le premier élément où le pointeur précédent est à NULL ( modifer le pointeur "racine" )
 
cas ou le meilleur est le dernier élément où le pointeur suivant est à NULL (sinon crash)


Message édité par bjone le 10-12-2002 à 16:30:04
n°266504
bjone
Insert booze to continue
Posté le 10-12-2002 à 16:32:44  profilanswer
 

et comme tu fais un courant=courant->suivant en fin de while
 
dans le if en cas d'insertion, il faut à la fin faire courant=meilleur, comme ça le courant pris au prochain coup sera le MEME que celui de ce tour là, et si il y a encore des élements mieux placés il seront insérés devant.
 

n°266521
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 16:49:17  profilanswer
 

bjone a écrit :

et comme tu fais un courant=courant->suivant en fin de while
 
dans le if en cas d'insertion, il faut à la fin faire courant=meilleur, comme ça le courant pris au prochain coup sera le MEME que celui de ce tour là, et si il y a encore des élements mieux placés il seront insérés devant.
 
 


Bon voila j'ai fais ce que tu as dis, enfin je crois :  
 

Code :
  1. void TriNom(struct DATA *LC_result)
  2. {
  3.    struct DATA *pMem, *pTmp, *pI, *pJ;
  4.    pI=LC_result;
  5.    while(pI->pSuivant != NULL && pI->pSuivant->pSuivant!=NULL)
  6.    {
  7.  pMem=pI;
  8.       pJ=pI->pSuivant;
  9.       while(pJ->pSuivant!=NULL)
  10.       {
  11.        if(strcmp(pJ->nom, pMem->nom)<0)
  12.          {
  13.    pMem=pJ;
  14.          }
  15.          pJ=pJ->pSuivant;
  16.       }
  17.       if(strcmp(pMem->nom, pI->nom)!=0)
  18.       {
  19.          pI->pPrecedent->pSuivant=pMem;
  20.          pI->pPrecedent=pMem;
  21.          pMem->pPrecedent->pSuivant=pMem->pSuivant;
  22.          pMem->pSuivant->pPrecedent=pMem->pPrecedent;
  23.          pMem->pSuivant=pI;
  24.       }
  25.     pI=pI->pSuivant;
  26.    }
  27.    getch();
  28. }


 
maintenant a TOUT les coup il manques un enregistrement.... c'est deja mieux, mais ca trie encore n'importe comment.
 
j'ai essaié de mettre pI=pMem; a la place de pI=pI->pSuivant; mais alrso il boucle a l'infini...  
 
désolé de t'ennuyé encore mais chui un peu largué la... stressé, car c'est la seule fonction de mon prog ki marche pas encore , et je dois remettre le projet demain :/
 
gros stress :'(
 
thkx


---------------
Ptit con de goret je t'emmerde ^_^
n°266538
BifaceMcLe​OD
The HighGlandeur
Posté le 10-12-2002 à 17:03:27  profilanswer
 

Algorithme de tri en O(n log n) pour les listes chaînées :
 
http://www.chiark.greenend.org.uk/ [...] tsort.html
 
Avec du code en C.
 
PS: Vive [:google]

n°266541
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 17:05:04  profilanswer
 

BifaceMcLeOD a écrit :

Algorithme de tri en O(n log n) pour les listes chaînées :
 
http://www.chiark.greenend.org.uk/ [...] tsort.html
 
Avec du code en C.
 
PS: Vive [:google]


 
Je v voir ca merci, puis, j'ai passé des heures sans trouver sur google... avec les criteres "tri de liste chainee" "langage C"
et rien :/
 
edit: un rien complexe a comprendre leur exemple :/


Message édité par _maximus_ le 10-12-2002 à 17:12:06

---------------
Ptit con de goret je t'emmerde ^_^
n°266560
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 17:25:29  profilanswer
 

bjone a écrit :

et comme tu fais un courant=courant->suivant en fin de while
 
dans le if en cas d'insertion, il faut à la fin faire courant=meilleur, comme ça le courant pris au prochain coup sera le MEME que celui de ce tour là, et si il y a encore des élements mieux placés il seront insérés devant.
 
 


dans mon dernier code tu vois qque chose qui cloche  :??:  
chai plus quoi faire pour ke ca marche :'(


---------------
Ptit con de goret je t'emmerde ^_^
n°266568
BifaceMcLe​OD
The HighGlandeur
Posté le 10-12-2002 à 17:33:54  profilanswer
 

_Maximus_ a écrit :


 
Je v voir ca merci, puis, j'ai passé des heures sans trouver sur google... avec les criteres "tri de liste chainee" "langage C"
et rien :/


Il faut savoir parler anglais parfois. Je l'ai trouvé en tapant "sort linked list".

n°266570
youdontcar​e
Posté le 10-12-2002 à 17:36:17  profilanswer
 

Si tu veux une solution simple ... une liste chaînée n'est qu'un container de données. Le container le plus simple à trier est le tableau - tu vas donc ranger tous les pointeurs de ta liste chaînée dans un tableau de DATA* temporaire. Ensuite, un qsort() sur ce tableau, puis recréation de la liste chaînée (simple parcours du tableau qui met pointeur suivant = case suivante, etc).
 
la fonction à passer à qsort va te filer deux pointeurs void* (en fait des pointeurs vers tes DATA*)
 
void fn(void* d1, void* d2)
 
tu n'as qu'à les caster puis faire ta comparaison dessus :
 
return strcmp((DATA*)d1->nom, (DATA*)d2->nom);

n°266587
_maximus_
Goret ptit con ^_^
Posté le 10-12-2002 à 17:50:22  profilanswer
 

youdontcare a écrit :

Si tu veux une solution simple ... une liste chaînée n'est qu'un container de données. Le container le plus simple à trier est le tableau - tu vas donc ranger tous les pointeurs de ta liste chaînée dans un tableau de DATA* temporaire. Ensuite, un qsort() sur ce tableau, puis recréation de la liste chaînée (simple parcours du tableau qui met pointeur suivant = case suivante, etc).
 
la fonction à passer à qsort va te filer deux pointeurs void* (en fait des pointeurs vers tes DATA*)
 
void fn(void* d1, void* d2)
 
tu n'as qu'à les caster puis faire ta comparaison dessus :
 
return strcmp((DATA*)d1->nom, (DATA*)d2->nom);


 
bon j'ai commencé mais je suis deja bloqué
 

Code :
  1. void TriNom(struct DATA *LC_result)
  2. {
  3. struct DATA *pMem, *pTmp, *pI, *pJ;
  4.    struct *DATA TabDATA[];
  5.    int i=0;
  6. while(pI->pSuivant!=NULL)
  7. {
  8.     TabDATA[i++]=pI;
  9. }
  10. qsort(*base, i, malloc(sizeof(struct DATA)), fn(/* que mettre ici*/));
  11. }
  12. void fn(void* d1, void* d2)
  13. {
  14. return strcmp((DATA*)d1->nom, (DATA*)d2->nom);
  15. }


 
j'parie que chui a coté de la plaque completement... :/


---------------
Ptit con de goret je t'emmerde ^_^
n°266593
youdontcar​e
Posté le 10-12-2002 à 18:01:11  profilanswer
 

void TriNom(struct DATA *LC_result)
{
 struct DATA *pMem, *pTmp, *pI, *pJ;
   struct *DATA TabDATA[];
   int i=0;
/*
  manque l'allocation du tableau ...
*/
 
 while(pI->pSuivant!=NULL)
 {
    TabDATA[i++]=pI;
 }
 
/*
  regarde l'aide de qsort (ou google). il faut un tableau, donc ici TabData, le nombre de ses éléments, la taille d'un élément (ici sizeof(DATA*)), puis la fonction de comparaison (regarde l'aide, compile un exemple et debugge-le pour voir comment la fonction est appelée).
*/
 qsort(*base, i, malloc(sizeof(struct DATA)), fn(/* que mettre ici*/));
}
 
/*
  manque la mise à jour des pointeurs. le quicksort a 'trié les pointeurs' vers les éléments de ta liste, suffit de parcourir le tableau et de faire TabData[i].pSuivant = TabData[i+1], etc. et faire gaffe aux valeurs de i.
 
donc le premier élément de ta liste sera TabData[0].
*/
 
/*
  pareil, regarde l'aide. maîtriser qsort() & ses mécanismes est indispensable.
*/
void fn(void* d1, void* d2)
{
 return strcmp((DATA*)d1->nom, (DATA*)d2->nom);
}

n°266788
bjone
Insert booze to continue
Posté le 10-12-2002 à 23:14:58  profilanswer
 

boh j'essayais de le mettre sur la voie :D

n°266871
_maximus_
Goret ptit con ^_^
Posté le 11-12-2002 à 07:43:23  profilanswer
 

bjone a écrit :

boh j'essayais de le mettre sur la voie :D


 
bjone, qu'est ce qui cloche alors dans ce que j'ai fait??  
 
capte pas [:spamafote]  
 
merci


---------------
Ptit con de goret je t'emmerde ^_^
n°266872
_maximus_
Goret ptit con ^_^
Posté le 11-12-2002 à 07:47:23  profilanswer
 

v devenir singléééé  :cry:


---------------
Ptit con de goret je t'emmerde ^_^
n°266885
youdontcar​e
Posté le 11-12-2002 à 09:06:00  profilanswer
 

_Maximus_ a écrit :

v devenir singléééé  :cry:

si tu détaillais un peu les endroits où tu es bloqué ... j'ai mis tout ce que tu avais à corriger dans mon post précédent. le code final ne devrait pas prendre plus d'une trentaine de lignes.
 
et quand je dis de recopier & debugger les exemples qsort() & co, c'est pas pour faire joli, c'est crucial. cf l'exemple dans la msdn : http://msdn.microsoft.com/library/ [...] _qsort.asp  
 
si tu veux comprendre l'algo, http://www.google.com/search?q=quicksort+explained . ce n'est pas indispensable pour son utilisation.

mood
Publicité
Posté le   profilanswer
 

 Page :   1  2
Page Précédente

Aller à :
Ajouter une réponse
  FORUM HardWare.fr
  Programmation
  C++

  [C / Algo] - Tri d'une liste chainée par nom [ résolu... oufff ! ]

 

Sujets relatifs
Ou puis-je trouver une liste de ts les pays pr mettre dans un combo?Serveur local impossible de passer des variable par url [résolu]
[ALGO] algo avec restriction de donnéepbr recherche en LDAP (newbie inside) [Résolu]
[Algo]ou trouver des infos sur le parcours des arbres ?[HTML]Comment recuperer ts les elt selectionnées d'une boîte liste?
Besoin d'un pro? : Problème de regexp (résolu)Délai dans la suppression des variables de session (résolu)
probleme avec un applet qui prend un fichier en parametre [resolu]comment recuperer le path du fichier qu'on execute ? [resolu]
Plus de sujets relatifs à : [C / Algo] - Tri d'une liste chainée par nom [ résolu... oufff ! ]


Copyright © 1997-2022 Hardware.fr SARL (Signaler un contenu illicite / Données personnelles) / Groupe LDLC / Shop HFR