begin process at 2010 03 17 03:04:52
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

API

 > [WIN32] TRIER UNE LISTBOX

[WIN32] TRIER UNE LISTBOX


 Information sur la source

Note :
8 / 10 - par 1 personne
8,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :API Niveau :Débutant Date de création :13/06/2005 Vu / téléchargé :6 105 / 514

Auteur : Hades53

Ecrire un message privé
Commentaire sur cette source (8)
Ajouter un commentaire et/ou une note

 Description

Cliquez pour voir la capture en taille normale
Exemple de code montrant comment trier les éléments d'une listbox, faites un clique droit sur la liste pour commencer.

La technique utilisée est assez simple, les éléments de la liste sont copiés dans un conteneur (<list>) qui, une fois que tous les éléments y sont copiés, sera trié. Au final au ajoute tous les éléments du conteneur dans la liste.
Cette technique peut paraître assez indirecte, mais il vaut peut être mieux procédèr comme cela, car les opérations de déplacement d'élément  de liste Win32 sont relativement 'lourdes' (LB_GETTEXT + LB_DELETESTRING + LB_INSERTSTRING = 1 déplacement) alors qu'avec les listes chaînées, c'est très rapide.  


 Conclusion

Le petite coloration de gauche ne sert strictement à rien ;)

 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Sources du même auteur

Source avec Zip Source avec une capture MORPIONS AVEC PRISE EN CHARGE RÉSEAU [WIN32]
LISTE DOUBLEMENT CHAÎNÉE GÉNÉRIQUE AVEC ITÉRATEURS
WILD_MATCH() - SAVOIR SI UN WILDCARD VALIDE UNE CHAÎNE
GETTOK() - OBTENIR LE NIÈME TOKEN
ISIN,ISWORD

 Sources de la même categorie

Source avec Zip Source avec une capture CALENDRIER (WIN64) par BruNews
Source avec Zip Source avec une capture IMPRESSION EN WIN32 API AVEC OPTIONS par racpp
Source avec Zip Source avec une capture INFOTIP SHELL EXTENSION (BULLE DE L'EXPLORATEUR WINDOWS) (WI... par racpp
Source avec Zip Source avec une capture BROUILLAGE DES FICHIERS JAVASCRIPT ET CSS(WIN32) par gagah1
Source avec Zip Source avec une capture CHANGE CURSEUR par ganjarasta

Commentaires et avis

Commentaire de poppyto le 13/06/2005 07:45:25 administrateur CS

Et le style LBS_SORT dans tout ça ? ^^

Commentaire de vecchio56 le 13/06/2005 10:23:14 administrateur CS

A sa décharge, son programme est un plus complet que LBS_SORT: tri selon un autre critère que l'ordre alphabétique, et tri d'une partie seulement de la listBox
C'est quand même interessant à mon avis

Commentaire de vecchio56 le 13/06/2005 10:26:51 administrateur CS

Hades53, plutot que de disable un warning comme ca, enlève plutot l'option /Wp64 (C/C++ > Général > Détection des problèmes de portabilité 64 bits)

Commentaire de Hades53 le 13/06/2005 23:38:15

poppyto: je crois que vecchio56 a tout dis ;)
vecchio56: ok, merci du conseil

Quelqu'un connaitrai-t-il un algo rapide de tri à l'insertion (déterminer la position future qu'aura un élément dans une liste triée) ?

Commentaire de vecchio56 le 14/06/2005 11:16:27 administrateur CS

Oui, la recherche dichotomique bien sur, tu pourra sans doute pas trouver plus rapide. Si cela doit te servir à faire des insertions, va voir du coté de map (arbre binaire), car un tableau permet la recherche dichotomique mais pas l'insertion, et une liste chainée c'est le contraire

Commentaire de Hades53 le 14/06/2005 22:53:37

Ok, j'ai fais une petite fonction dichotomique (en m'inspirant d'exemple de recherche dichotomique) pour obtenir la position qu'un élément devrait avoir dans la listbox, mais la fonction ne donne pas toujours la bonne position.

int ListCompare(const char *cle, int index) {
__int64 comp = 0;
int size = (int)SendMessage(hlist,LB_GETTEXTLEN,index,NULL);
char *elm = new char[size + 1];
SendMessage(hlist,LB_GETTEXT,index,(LPARAM)elm);
switch (tsort) {
case POP_AZSORT: case POP_ZASORT:
comp = lstrcmpi(elm,cle);
delete[] elm;
if (!comp) return 0;
if (comp < 0) return tsort == POP_AZSORT ? -1 : 1;
return tsort == POP_AZSORT ? 1 : -1;
case POP_09SORT: case POP_90SORT:
comp = _atoi64(elm) - _atoi64(cle);
delete[] elm;
if (!comp) return 0;
if (comp < 0) return tsort == POP_09SORT ? -1 : 1;
return tsort == POP_09SORT ? 1 : -1;
case POP_ALSORT: case POP_DLSORT:
comp = size - lstrlen(cle);
delete[] elm;
if (!comp) return 0;
if (comp < 0) return tsort == POP_ALSORT ? -1 : 1;
return tsort == POP_ALSORT ? 1 : -1;
}
return 0;
}

int GetSortedPos(const char *cle, int a, int b, int reserved) {
int m, c, j = 0;
while (a <= b) {
m = ((a + b) / 2);
c = ListCompare(cle,m);
if (!c) return m;
else if (c > 0) {
b = m - 1 ;
j = m ;
}
else {
a = m + 1;
j = m + 1;
}
}
return j != NULL ? j : (int)SendMessage(hlist,LB_GETCOUNT,NULL,NULL);
}

Pour insérer, je fais: SendMessage(hwnd,LB_INSERTSTRING,(WPARAM)GetSortedPos(chaine,0,(int)SendMessage(hwnd,LB_GETCOUNT,NULL,NULL) - 1  ,NULL),(LPARAM)chaine);

Le problème vient bien évidement de la fonction GetSortedPos(), arrive-tu à voir ce qui cloche ?

Commentaire de poppyto le 14/06/2005 23:01:32 administrateur CS

Désolé :oP

Commentaire de Hades53 le 15/06/2005 01:49:03

C'est bon, j'ai trouvé =] :

int GetSortedPos(const char *cle, int a, int b)
{
b -= 1;
int m , comp;
while (a <= b) {
m = (a + b) / 2;
comp = ListCompare(cle,m);
if (comp > 0) b = m - 1;
else if (comp < 0) a = m + 1;
else return m;
}
return a;
}

 Ajouter un commentaire




Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Mars 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
293031    

Consulter la suite du CalendriCode

Photothèque

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,718 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales