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 :

comparer deux tableaux


Sujet :

Langage Perl

  1. #1
    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 : 498 771
    Points
    498 771
    Par défaut comparer deux tableaux
    Je suis en train de m'amuser à ecrire une fonction elegante et rapide permettant de comparer deux tableaux (si vous en avez, je suis preneur). J'ai reussi pour comparer les tableaux n'ayant pas de doublons. Mais pour les autres cas, c'est plus complex.
    Sinon, j'aurais une question.
    comment supprimer proprement un element d'un tableau?
    Je sais qu'on peut faire delete, mais ça ne m'aide pas trop, ex :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    my @fruits=(1,2,3,4,5,6);
    $,=" ";
    print scalar(@fruits),"|| ", @fruits,"\n";
    delete($fruits[1]);
    print  scalar(@fruits),"|| ", @fruits,"\n";
    resultat
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Use of uninitialized value in print line 14.
    6 ||  1 2 3 4 5 6 
    6 ||  1  3 4 5 6
    la valeur est supprimée (ou du moins mise à undef) et j'ai un message d'erreur et j'ai toujours 6 elts dans mon tableau, que faire?

  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
    Je manque un peu de temps pour une réponse plus complète (sur la comparaison, notamment), mais pour gérer les undefs résultants de deletes dans des tableaux, j'ai parfois utilisé grep.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    @fruits = grep { defined } @fruits;
    Sinon, il y a aussi la solution de supprimer par recréation d'un nouveau tableau, à coup de tranches, plutôt que par delete.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    if ($a_supprimer == 0) {
      @fruits = @fruits[($a_supprimer+1)..$#fruits];
    } elsif ($a_supprimer == $#fruits) {
      @fruits = @fruits[0..$#fruits-1];
    } else {
    @fruits = @fruits[((0..($a_supprimer-1)),($a_supprimer+1..$#fruits))];
    }
    Je ne sais pas réellement ce qui est le plus efficace pour les gros tableaux ...

    [Edit]
    Dans la suppressions à coup de tranche, il faut, bien évidemment, gérer l'absence de suppression si l'élément indiqué $a_supprimer est hors bornes du tableau, ce que je n'ai pas fait ici
    [/Edit]
    La FAQ Perl est par ici
    : La fonction "Rechercher", on aurait dû la nommer "Retrouver" - essayez et vous verrez pourquoi !

  3. #3
    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 : 498 771
    Points
    498 771
    Par défaut
    en faite, si on veut comparer deux tableaux de n cases, la façcon la plus barbare est de faire deux boucles.
    Mais afin d'eviter n*n comparaison, je faire des delete au fur et à mesure qu'un elt est trouvé, ce qui reduit déjà pas mal le nombre de comparaison.
    Ta solution de recreer un new tableau me plait bien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    @fruits = grep { defined } @fruits;
    mais je sais pas si du coup niveau optimisation, ça le fait : car à chaque parcour du tableau, faudra faire un grep??

  4. #4
    tfe
    tfe est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    85
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 85
    Points : 95
    Points
    95
    Par défaut
    pour les doublons y a tout dans la doc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    perldoc -q array
    How can I remove duplicate elements from a list or array?

    puis comparaison
    How do I test whether two arrays or hashes are equal?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
            sub compare_arrays {
                   my ($first, $second) = @_;
                   no warnings;  # silence spurious -w undef complaints
                   return 0 unless @$first == @$second;
                   for (my $i = 0; $i < @$first; $i++) {
                       return 0 if $first->[$i] ne $second->[$i];
                   }
                   return 1;
               }
    il y a egalement une fonction pour les structures plus compexes mais bon... A prioris le code est donné juste a titre d exemple; c est sur que ca doit pas etre optimal :S

  5. #5
    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 : 498 771
    Points
    498 771
    Par défaut
    je l'ai bien vu ce script, y a plus simple. c'est uniquement pour des tableaux simples et de plus il compare case contre case.
    Sinon j'ai pu faire ma fonction comparant les tableaux (à une dimension et avec ou sans doublons)
    merci qd même tfe

Discussions similaires

  1. Comparer deux tableaux
    Par Boubou382002 dans le forum Excel
    Réponses: 19
    Dernier message: 12/11/2008, 19h20
  2. Comment comparer deux tableaux
    Par bmeda72 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 18/08/2008, 09h37
  3. [Tableaux] Comparer deux tableaux
    Par popy67 dans le forum Langage
    Réponses: 2
    Dernier message: 05/05/2008, 07h22
  4. Comparer deux tableaux
    Par gefrey54 dans le forum Powerbuilder
    Réponses: 0
    Dernier message: 12/09/2007, 10h58

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