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

Collection et Stream Java Discussion :

Trie de HashMap avec un TreeSet


Sujet :

Collection et Stream Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2011
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Février 2011
    Messages : 71
    Par défaut Trie de HashMap avec un TreeSet
    Bonjour,

    J'ai un petit problème pour trier une hashMap par valeur voila le code correspondant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
     
    String dirName="leRepertoirAParcourir"
    Double similarity;
    File dir = new File(dirName);
    HashMap<String, Double> docSimilarities = new HashMap<String, Double>();
    if(dir.isDirectory()){
    			//Liste des fichiers du repertoire, ajouter un FileNameFilter si necessaire
    			String[] fileNames = dir.list();
    			for(String fileName2 : fileNames){
    				String completeFileName = dirName + File.separator + fileName2;
    				similarity = getSimilarity(fileName, completeFileName);
    				docSimilarities.put(fileName2, similarity);
    			}
    		}
     
    TreeSet<String> files = new TreeSet<String>(new Comparator<String>() {
    			public int compare(String o1, String o2){
    				//ordre inverse des valeurs
    				return Double.compare(docSimilarities.get(o2), docSimilarities.get(o1));
    			}
    		});
    		files.addAll(docSimilarities.keySet());
     
    		System.out.println("taille de files   "+ files.size() + "  tailleHashMap =  "+docSimilarities.size());
    		for(String file:files)
    			System.out.println(file + "  :  " + docSimilarities.get(file));

    sachant que tous les noms de fichiers sont unique je ne comprend pas pourquoi j'ai la tracestack suivante :

    taille de files 904 tailleHashMap = 3204
    alors que je m'attend à ce qu'il soit tous les deux à la même taille.

  2. #2
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2011
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Février 2011
    Messages : 71
    Par défaut
    Aucune idée?

  3. #3
    Membre éprouvé
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2010
    Messages
    119
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2010
    Messages : 119
    Par défaut
    La comme ça non, t'as tenté d'afficher tes deux listes pour voir ce qu'elles contiennent ?

  4. #4
    Modérateur

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    12 582
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 582
    Par défaut
    Un TreeSet est un Set. Si deux éléments produisent zéro au compare(), un seul d'entre eux sera gardé.
    En l'occurence, si deux fichiers ont la même valeur Double, un seul sera gardé. C'est d'ailleurs pour cette seule et unique raison qu'on peut vouloir utiliser un Set : ne pas avoir de doublon.

    Si tu veux pouvoir contenir plusieurs fichiers différents qui ont le même Double mais qui sont classés dans l'ordre, il vaut mieux les mettre dans une List<String> et appliquer Collections.sort() sur cette List en lui fournissant ton Comparator<String>.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2011
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Février 2011
    Messages : 71
    Par défaut
    Oui c'est bien, il supprime les doublons de valeurs.
    La solution proposé fonctionne merci thelvin

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

Discussions similaires

  1. Stress avec un TreeSet
    Par Eclipse39 dans le forum Débuter avec Java
    Réponses: 2
    Dernier message: 10/01/2009, 17h15
  2. HashTable ou HashMap avec plusieurs indexes ?
    Par Esil2008 dans le forum Collection et Stream
    Réponses: 5
    Dernier message: 19/05/2008, 09h45
  3. hashmap avec plus de 3 arguments
    Par ____22 dans le forum Collection et Stream
    Réponses: 1
    Dernier message: 12/05/2008, 17h23
  4. Hashmap avec 3 éléments
    Par inès83 dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 17/04/2008, 22h54
  5. le trie des colonne avec JXTable de xswing
    Par L4BiN dans le forum AWT/Swing
    Réponses: 5
    Dernier message: 19/02/2007, 11h10

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