Tri de cartes
Les cartes sont utilisées pour stocker des paires clé-valeur. Nous pouvons trier les cartes selon leurs clés ou leurs valeurs. TreeMap peut également être utilisé pour stocker des paires clé-valeur dans un ordre trié.
Le code suivant montre comment trier une carte d'entiers à l'aide de la méthode sort()
:
public static void main(String[] args) {
Map<Integer, String> map = new TreeMap<Integer, String>();
map.put(6, "Apple");
map.put(3, "Banana");
map.put(1, "Mango");
map.put(9, "Orange");
System.out.println("Carte avant le tri : " + map);
// Tri par clés
Map<Integer, String> sortedByKeyMap = new TreeMap<Integer, String>(map);
System.out.println("Carte après le tri par clés : " + sortedByKeyMap);
// Tri par valeur
List<Map.Entry<Integer, String>> list = new ArrayList<Map.Entry<Integer, String>>(map.entrySet());
Collections.sort(list, new Comparator<Map.Entry<Integer, String>>() {
public int compare(Map.Entry<Integer, String> o1, Map.Entry<Integer, String> o2) {
return (o1.getValue()).compareTo(o2.getValue());
}
});
Map<Integer, String> sortedByValueMap = new LinkedHashMap<Integer, String>();
for (Map.Entry<Integer, String> entry : list) {
sortedByValueMap.put(entry.getKey(), entry.getValue());
}
System.out.println("Carte après le tri par valeurs : " + sortedByValueMap);
}
Pour exécuter ce code, accédez au répertoire ~/projet
dans le terminal et exécutez les commandes suivantes :
$ javac Tri.java
$ java Tri
Ce code triera la carte selon ses clés et ses valeurs.