Maison >Java >javaDidacticiel >Comment trier une liste en fonction de l'ordre d'une autre liste en Java ?

Comment trier une liste en fonction de l'ordre d'une autre liste en Java ?

Barbara Streisand
Barbara Streisandoriginal
2024-11-02 15:46:291012parcourir

How to Sort One List Based on the Order of Another List in 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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn