Maison >Java >javaDidacticiel >Comment trier une liste en fonction de l'ordre d'une autre liste en Java ?
Tri d'une liste en fonction d'une autre en Java
En Java, il est possible de trier une liste en fonction de l'ordre d'une autre liste. Cela peut être utile dans les situations où vous avez une séquence spécifique d'éléments dans une liste (listB) et que vous souhaitez réorganiser une deuxième liste (listA) pour qu'elle corresponde à cet ordre.
Une façon d'y parvenir est d'utiliser la méthode Collections.sort() avec un Comparator personnalisé comme suit :
<code class="java">Collections.sort(listToSort, new Comparator<T>() { @Override public int compare(T o1, T o2) { return listWithOrder.indexOf(o1) - listWithOrder.indexOf(o2); } });</code>
Ici, listToSort représente votre liste non triée et listWithOrder contient l'ordre souhaité. Ce comparateur trie listToSort en fonction de l'ordre des éléments dans listWithOrder.
Pour Java 8 et versions ultérieures, vous pouvez simplifier le code à l'aide de lambdas et de la méthode comparantInt() :
<code class="java">listToSort.sort(Comparator.comparingInt(listWithOrder::indexOf));</code>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!