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
Libérer: 2024-11-02 15:46:29
original
1040 Les gens l'ont consulté

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>
Copier après la connexion

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>
Copier après la connexion

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 de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal