【Java】Java中对List进行排序

探讨几种Java对List进行排序的方法。

使用Collections.sort()方法

Java中的Collections.sort()方法是对List进行排序的最常用方法。它使用TimSort算法(是一种稳定的,基于合并的排序算法,是插入排序和归并排序的混合体),具有O(n log n)的时间复杂度。

java 复制代码
import java.util.*;  
  
public class Main {  
    public static void main(String[] args) {  
        List<Integer> numbers = new ArrayList<>();  
        numbers.add(5);  
        numbers.add(9);  
        numbers.add(1);  
        numbers.add(3);  
  
        Collections.sort(numbers);  
  
        System.out.println(numbers);  // 输出:[1, 3, 5, 9]  
    }  
}

使用Java 8的Stream API

Java 8引入了Stream API,它提供了一种新的方式来处理集合。你可以使用Stream API对List进行排序。

java 复制代码
import java.util.*;  
import java.util.stream.Collectors;  
  
public class Main {  
    public static void main(String[] args) {  
        List<Integer> numbers = new ArrayList<>();  
        numbers.add(5);  
        numbers.add(9);  
        numbers.add(1);  
        numbers.add(3);  
  
        List<Integer> sortedNumbers = numbers.stream()  
            .sorted()  
            .collect(Collectors.toList());  
  
        System.out.println(sortedNumbers);  // 输出:[1, 3, 5, 9]  
    }  
}

在这个例子中,我们首先把List转换为Stream,然后使用sorted()方法对元素进行排序,最后我们收集结果并创建一个新的有序的List。

使用自定义比较器

如果你需要对自定义对象进行排序,或者需要使用特定的排序标准,你可以使用自定义比较器。比较器需要实现Comparator接口,并覆盖compare()方法。

java 复制代码
import java.util.*;  
  
public class Main {  
    public static void main(String[] args) {  
        List<String> words = new ArrayList<>();  
        words.add("banana");  
        words.add("apple");  
        words.add("cherry");  
        words.add("date");  
  
        Collections.sort(words, new Comparator<String>() {  
            @Override  
            public int compare(String word1, String word2) {  
                return word1.length() - word2.length();  
            }  
        });  
  
        System.out.println(words);  // 输出:[date, apple, cherry, banana]  
    }  
}

在这个例子中,我们使用了一个自定义比较器,它将字符串按照长度进行排序。如果第一个字符串的长度小于第二个字符串的长度,compare()方法将返回一个负数;如果长度相等,它将返回0;如果第一个字符串的长度大于第二个字符串的长度,它将返回一个正数。这样,Collections.sort()方法就会按照我们指定的方式进行排序。

相关推荐
小北方城市网2 分钟前
JavaScript 实战 —— 实现一个简易的 TodoList(适合前端入门 / 进阶)
开发语言·前端·javascript
向上_503582915 分钟前
配置Protobuf输出Java文件或kotlin文件
android·java·开发语言·kotlin
njidf7 分钟前
C++中的观察者模式
开发语言·c++·算法
IAUTOMOBILE8 分钟前
C++ 入门基础:开启编程新世界的大门
java·jvm·c++
秋野酱12 分钟前
基于springboot的母婴商城系统设计与实现(源码+文档+部署讲解)
java·spring boot·后端
艾莉丝努力练剑17 分钟前
alarm系统调用的一次性原理揭秘
linux·运维·服务器·开发语言·网络·人工智能·学习
无籽西瓜a23 分钟前
【西瓜带你学设计模式 | 第二期-观察者模式】观察者模式——推模型与拉模型实现、优缺点与适用场景
java·后端·观察者模式·设计模式
探序基因27 分钟前
安装空间转录组分析软件-R包SPATA2的安装
开发语言·r语言
春日见38 分钟前
E2E自驾规控30讲:环境搭建
开发语言·驱动开发·matlab·docker·计算机外设
念何架构之路44 分钟前
Go语言表达式的求值顺序
开发语言·后端·golang