温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java Comparator如何实现稳定排序

发布时间:2025-05-20 09:37:13 来源:亿速云 阅读:98 作者:小樊 栏目:编程语言

在Java中,要实现稳定的排序,你需要使用Collections.sort()方法,并提供一个自定义的ComparatorCollections.sort()方法在Java 8及更高版本中使用的是稳定的TimSort算法,这意味着在排序过程中,相等的元素会保持它们原始的顺序。

下面是一个简单的示例,展示了如何使用Comparator实现稳定排序:

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class StableSortExample {
    public static void main(String[] args) {
        List<Person> people = new ArrayList<>();
        people.add(new Person("Alice", 30));
        people.add(new Person("Bob", 25));
        people.add(new Person("Charlie", 25));
        people.add(new Person("David", 30));

        // 使用Comparator实现稳定排序
        Collections.sort(people, new Comparator<Person>() {
            @Override
            public int compare(Person p1, Person p2) {
                // 首先根据年龄进行排序
                int ageComparison = Integer.compare(p1.getAge(), p2.getAge());
                if (ageComparison != 0) {
                    return ageComparison;
                }
                // 如果年龄相同,则根据名字进行排序(保持稳定性)
                return p1.getName().compareTo(p2.getName());
            }
        });

        // 输出排序后的列表
        for (Person person : people) {
            System.out.println(person);
        }
    }

    static class Person {
        private String name;
        private int age;

        public Person(String name, int age) {
            this.name = name;
            this.age = age;
        }

        public String getName() {
            return name;
        }

        public int getAge() {
            return age;
        }

        @Override
        public String toString() {
            return "Person{" +
                    "name='" + name + '\'' +
                    ", age=" + age +
                    '}';
        }
    }
}

在这个示例中,我们创建了一个Person类,并使用Collections.sort()方法对其进行排序。我们提供了一个自定义的Comparator,首先根据年龄进行排序,如果年龄相同,则根据名字进行排序。由于TimSort算法是稳定的,因此在排序过程中,具有相同年龄的人将保持他们原始的顺序。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI