IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage Perl Discussion :

Tri de tableaux 2D


Sujet :

Langage Perl

  1. #1
    Futur Membre du Club
    Inscrit en
    Septembre 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 8
    Points : 5
    Points
    5
    Par défaut Tri de tableaux 2D
    Bonjour,
    Je recherche une méthode rapide pour trier par ordre numérique un tableau 2D selon une de ses colonnes.
    J'ai regardé su côté de la fonction sort mais il semble que je ne puisse traiter que des tableaux 1D avec , non ?

    Merci d'avance de votre aide

  2. #2
    Membre expert
    Avatar de 2Eurocents
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    2 177
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 2 177
    Points : 3 166
    Points
    3 166
    Par défaut Re: Tri de tableaux 2D
    Citation Envoyé par LeRoiDesLutins
    Bonjour,
    Je recherche une méthode rapide pour trier par ordre numérique un tableau 2D selon une de ses colonnes.
    J'ai regardé su côté de la fonction sort mais il semble que je ne puisse traiter que des tableaux 1D avec , non ?
    Non ...

    On en a déjà parlé dans ce fil, entre autres.

    A toi d'adapter à ta structure de tableau.

    Bon courage ...
    La FAQ Perl est par ici
    : La fonction "Rechercher", on aurait dû la nommer "Retrouver" - essayez et vous verrez pourquoi !

  3. #3
    Futur Membre du Club
    Inscrit en
    Septembre 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 8
    Points : 5
    Points
    5
    Par défaut
    Oui, j'avais vu ce topic mais j'ai rien compris
    Pourrais tu prendre un peu de temps pour m'expliquer ça ?
    Merci de ton aide en tout cas

  4. #4
    Membre expert
    Avatar de 2Eurocents
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    2 177
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 2 177
    Points : 3 166
    Points
    3 166
    Par défaut
    Pas de problème ... essayons.

    C'est peut être jouer sur les mots, mais en Perl, il vaut mieux essayer d'éviter de penser en "tableaux", car on risque d'être toujours déçu.

    Comme tu le soulignes, les "tableaux" sont en 1D, pas 2D, 3D ou plus.

    En fait, la notion qui colle le mieux, dans ce cas, c'est la notion de liste. Que cette liste contienne des éléments composites, d'autres listes ou au contraire des éléments atomiques (insécables) n'a aucune espèce d'importance pour Perl.

    La fonction sort trie les listes.

    Cependant, pour nous permettre toutes les fantaisies en fonction de ce que contiennent les listes, elle accepte un bloc de code qu'elle peut utiliser pour réaliser ce tri.

    Il faut savoir que dans ce bloc de code, le premier des éléments de la liste à trié considéré pour le tri est conventionnelement nommé $a, et le second $b (ce sont des variables internes au tri, qu'il est donc superflu de déclarer).

    Le tri sera réalisé en fonction du résultat de la comparaison menée sur $a et $b dans le bloc de code.

    Les tris élémentaires sont généralement du style de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort { $a cmp $b } @liste
    pour les listes de chaines,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort { $a <=> $b } @liste
    pour les listes de nombres.

    Cependant, rien n'empêche d'utiliser $a et $b comme des éléments d'indirection pour trier des listes d'éléments plus complexes.

    Par exemple, pour un hachage :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort { $a cmp $b } keys %hachage
    trie les clefs du hachage par ordre croissant.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort { $hachage{$a} cmp $hachage{$b} } keys %hachage
    trie les clefs du hachage par ordre de valeur correspondante croissante.

    De même, à supposer que la liste soit une liste composée d'éléments aggrégés (des champs de données, concaténés, séparés par des virgules, par exemple), il est possible de décomposer ces éléments dans le bloc de tri, et d'utiliser le résultat de la comparaison entre deux parties pour trier l'ensemble de la liste :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort { my @champs_a = split (/,/, $a); my @champs_b = split (/,/, $b); $champs_a[5] <=> $champs_b[5] } @liste
    Ceci triera la liste en comparant (numériquement) le sixième champ de l'ensemble de champs séparés par des virgules (pour des valeurs de la forme "aaa,bbb,xxx,yyy,zzz,123,etc" dans chaque élément de la liste).


    Est-ce plus clair pour toi ?

    N'hésite pas à mener quelques essais, faire quelques tris ... disposer d'un langage interprété minimise le coût des essais nécessaires pour comprendre le fonctionnement de ses structures ... on peut tester et voir tout de suite comment ça fonctionne (ou pas).


    Bon courage.
    La FAQ Perl est par ici
    : La fonction "Rechercher", on aurait dû la nommer "Retrouver" - essayez et vous verrez pourquoi !

  5. #5
    Futur Membre du Club
    Inscrit en
    Septembre 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 8
    Points : 5
    Points
    5
    Par défaut
    Merci, je vais étudier tout ça (c'est chaud quand même ). J'ai plutôt l'habitude de Matlab et du Fortran... ça me change

  6. #6
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 499 184
    Points
    499 184
    Par défaut
    bienvenu dans ce beau monde de perléens

  7. #7
    Futur Membre du Club
    Inscrit en
    Septembre 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 8
    Points : 5
    Points
    5
    Par défaut
    Bien merci, je crois que j'ai à peu près compris la philosophie de la chose :o

    Je pense que j'ai trouvé la soluce !!



    Pour ceux que ça peut aider -> pour trier un tableau à deux dimensions (désolé pour l'appelation contre-perl-culture ) du type "$tab2D[$i][$j] = $x" sur la première colonne (indice 0) par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    @tab2D = sort { @$a[0] <=> @$b[0] } @tab2D;

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Tableaux] Tri de tableaux associatifs à 2 dimensions
    Par max44410 dans le forum Langage
    Réponses: 4
    Dernier message: 18/05/2007, 03h54
  2. [Probleme] tri croissant - tableaux (débutant)
    Par tarnak dans le forum VB 6 et antérieur
    Réponses: 5
    Dernier message: 01/07/2006, 21h01
  3. Tri de tableaux multiples
    Par hdd dans le forum Langage
    Réponses: 4
    Dernier message: 02/06/2006, 17h54
  4. [Tableaux] tri sur tableaux
    Par pounie dans le forum Langage
    Réponses: 5
    Dernier message: 03/03/2006, 21h19

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo