【java】对ArrayList中的元素进行排序的几种方式

对ArrayList中的元素进行排序的几种方式

一、使用Collections工具类

1、对基本类型排序

通过Collections.sort()对基本类型排序默认是以升序排序

// 1.Collections.sort()默认按照升序排序
List<Integer> integerList = new ArrayList<>();
Collections.addAll(integerList,1,2,6,5,5,4,55,4,5,5,4,5,2,4,6,2,45);
Collections.sort(integerList);
System.out.println(integerList);
2、对字符串类型排序

对字符串类型排序默认按照首字母a-z排序

// 2.对字符串类型排序
List<String> strings = new ArrayList<>();
Collections.addAll(strings,"d","gsf","trh","fsd","an");
Collections.sort(strings);
System.out.println(strings);
3、对对象排序

如何使用Collections对对象排序呢?

在这里插入图片描述

其实只需要让我们的数据类型实现Comparable接口即可,下面定义一个实现Comparable接口的学生类,并且实现compareTo方法,让学生类只比较年龄。

/**
 * 学生
 *
 * @author ez4sterben
 * @date 2023/07/18
 */
public class Student implements Comparable<Student> {

    private String id;
    private String name;
    private Integer age;
    private String sex;

    @Override
    public String toString() {
        return "Student{" +
                "age=" + age +
                '}';
    }

    public Student(Integer age) {
        this.age = age;
    }

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    @Override
    public int compareTo(Student o) {
    	// 这种是升序
        return this.getAge() - o.getAge();
        // 这种是降序
        // return o.getAge() - this.getAge();
    }
}

排序方法和正常使用一样,直接把整个list传入即可

// 3.对对象排序
        List<Student> students = new ArrayList<>();
        Collections.addAll(students,
                new Student(18),
                new Student(26),
                new Student(20),
                new Student(16),
                new Student(12));
        System.out.println(students);
        Collections.sort(students);
        System.out.println(students);

在这里插入图片描述

二、使用stream流

// 2.lambda表达式
        Stream<Integer> sorted = integerList.stream().sorted();
        System.out.println(Arrays.toString(sorted.toArray()));

在这里插入图片描述

三、使用排序算法(以冒泡排序为例)

// 3.直接使用排序算法(以冒泡排序为例)
        for(int i = 0; i < integerList.size() - 1; i++){
            for(int j = 0; j < integerList.size() - i - 1; j++){
                if(integerList.get(j) > integerList.get(j + 1)){
                    Integer temp = integerList.get(j);
                    integerList.set(j, integerList.get(j + 1));
                    integerList.set(j + 1, temp);
                }
            }
        }
        System.out.println(integerList);

在这里插入图片描述

四、测试类整体代码

import java.util.*;
import java.util.stream.Stream;

/**
 * 数组列表排序
 *
 * @author ez4sterben
 * @date 2023/07/19
 */
public class ArrayListSort {
    public static void main(String[] args) {
        List<Integer> integerList = new ArrayList<>();
        Collections.addAll(integerList,1,2,6,5,5,4,55,4,5,5,4,5,2,4,6,2,45);
        // 1.Collections.sort()默认按照升序排序
        Collections.sort(integerList);
        System.out.println(integerList);
        // 2.对字符串类型排序
        List<String> strings = new ArrayList<>();
        Collections.addAll(strings,"d","gsf","trh","fsd","an");
        Collections.sort(strings);
        System.out.println(strings);
        // 3.对对象排序
        List<Student> students = new ArrayList<>();
        Collections.addAll(students,
                new Student(18),
                new Student(26),
                new Student(20),
                new Student(16),
                new Student(12));
        System.out.println(students);
        Collections.sort(students);
        System.out.println(students);

        // 2.lambda表达式
        Stream<Integer> sorted = integerList.stream().sorted();
        System.out.println(Arrays.toString(sorted.toArray()));

        // 3.直接使用排序算法(以冒泡排序为例)
        for(int i = 0; i < integerList.size() - 1; i++){
            for(int j = 0; j < integerList.size() - i - 1; j++){
                if(integerList.get(j) > integerList.get(j + 1)){
                    Integer temp = integerList.get(j);
                    integerList.set(j, integerList.get(j + 1));
                    integerList.set(j + 1, temp);
                }
            }
        }
        System.out.println(integerList);

    }
}

  • 4
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: Java语言可以使用以下几种方式排序List集合: 1. 实现Comparable接口:让集合元素实现Comparable接口,并重写compareTo方法。使用Collections.sort()方法对集合排序。 2. 实现Comparator接口:使用Comparator接口的实现类来定义排序规则。使用Collections.sort(List, Comparator)方法对集合排序。 3. Java 8 Stream API:使用Stream API的sorted方法对集合排序。 4. 使用数组排序:将集合转换成数组,使用Arrays.sort()方法对数组排序,最后再将数组转换回集合。 ### 回答2: Java语言的List集合可以使用多种方式进行排序,以下列举了几种常见的方法: 1. 使用Collections.sort()方法:通过调用Collections类的sort()方法,可以按照集合元素的自然顺序进行排序。例如: ```java List<Integer> list = new ArrayList<>(); // 添加元素到list Collections.sort(list); ``` 2. 使用Comparator接口:通过实现Comparator接口,可以定义自定义的排序规则。例如: ```java List<String> list = new ArrayList<>(); // 添加元素到list Collections.sort(list, new Comparator<String>() { @Override public int compare(String s1, String s2) { return s1.compareTo(s2); } }); ``` 3. 使用lambda表达式:Java 8及以上版本支持使用lambda表达式进行简洁的排序操作。例如: ```java List<String> list = new ArrayList<>(); // 添加元素到list list.sort((s1, s2) -> s1.compareTo(s2)); ``` 4. 使用Stream API:Java 8及以上版本提供了Stream API,可以方便地对集合元素进行排序。例如: ```java List<Integer> list = new ArrayList<>(); // 添加元素到list List<Integer> sortedList = list.stream().sorted().collect(Collectors.toList()); ``` 以上是Java语言List集合排序几种常见方式,可以根据具体的需求选择适合的方法进行排序操作。 ### 回答3: 在Java语言,对List集合进行排序几种方式如下: 1. 使用Collections.sort()方法:可以通过调用Collections类的sort()方法对List集合进行排序。方法原型为: ```java public static <T extends Comparable<? super T>> void sort(List<T> list) ``` 此方法会使用集合元素的自然顺序进行排序。 2. 实现Comparable接口:若集合元素是自定义的对象,可以让对象实现Comparable接口,并重写其的compareTo()方法来指定对象之间的比较规则。然后调用Collections.sort()方法对List集合进行排序。 3. 使用Comparator比较器:使用Comparator接口的实现类来指定元素的比较规则。可以通过创建Comparator的实例,并重写compare()方法来实现自定义的比较规则。然后再调用Collections.sort()方法并传入Comparator参数进行排序。 4. 使用lambda表达式:在Java 8及以后的版本,可以使用lambda表达式对List集合进行排序。可以通过使用List的sort()方法,将Comparator接口的实现作为参数传入进行排序。例如: ```java list.sort((a, b) -> a.compareTo(b)); ``` 5. 使用Stream API:在Java 8及以后的版本,可以使用Stream API对List集合进行排序。通过调用List的stream()方法,再调用sorted()方法来进行排序。对于自定义对象,可以重写Comparable接口或使用Comparator指定排序规则。 总之,Java语言对List集合进行排序可以通过调用Collections.sort()方法、实现Comparable接口、使用Comparator比较器、使用lambda表达式或使用Stream API等方式来实现。具体选择哪种方式取决于业务需求和个人偏好。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值