java基础 三种方式对int类型的List集合排序(通用排序)

首先我们定义一个List并且add元素

List list = new ArrayList();
        list.add(1);
        list.add(89);
        list.add(45);
        list.add(38);
        list.add(90);

第一种方法:运用java.util.Collections这个jdk提供的类
Collections.sort(list);这个方法根据元素的自然顺序 对指定列表按升序进行排序。这样就可以实现升序排序,如果是倒序的话也很简单,就将排好序的list反转过来,通过Collections.reverse(list);即可。
Collections这个工具类中还好很多的方法提供使用,这里就介绍这两个,可以自己查阅JDK的API文档。
第二种方法:根据冒泡排序来

    /**
     * @param list
     * @param operation 操作符:>表示升序,<表示降序
     */
    public static void sortList(List list ,String operation) {
        for (int i = 0; i < list.size(); i++) {
            for (int j = 0; j < list.size()-i-1; j++) {
                    int a = Integer.parseInt(list.get(j).toString());  
                    int b = Integer.parseInt(list.get(j+1).toString());
                    if(">".equals(operation)){
                        if(a>b){
                            list.set(j, b);
                            list.set(j+1, a);
                    }
                }else{
                    if(a<b){
                        list.set(j, b);
                        list.set(j+1, a);
                }
                }
            }
        }
    }

sortList(list,operation);通过传入指定的list和操作符便可对list进行升序和降序的排列。

第三种方法:第一种方法的时候我们已经了解到了Collections.sort()。在Collections类里还有这个方法的重载。Collections.sort(list,comparator);这个就厉害啦可以让我们自己去实现一个比较器comparator。这样就方便扩展了,不管要排序的集合是什么或者是集合内要什么规则排序我们都可以自己来实现,下来我们还是对int类型的来举个例子

public class Test {
    /**
     *排序
     */
    public void sortList(List<Integer> list){
        ComparatorList cl = new ComparatorList();
        Collections.sort(list, cl);
    }

    /**
     * 内部类来自己实现比较器的接口,按照我们自己的排序规则
     *
     */
    class ComparatorList implements Comparator<Integer>{
        @Override
        public int compare(Integer o1, Integer o2) {
            return o1>o2 ? 1:-1;//这里返回的值,1升序 -1降序
        }

    }

    public static void main(String[] args){
        Test test = new Test();
        List<Integer> list = Arrays.asList(4,5,6,3,6,9,1,2);
        test.sortList(list);
        for(Integer i : list){
            System.out.println(i);
        }
    }
}
// 通过这种自己来实现比较器的方式,想List<对象>,List<Map<String, Object>>,
// List<List<Object>> 复杂的都可以来进行排序

    /**
     * 下面这部分就是对List<Map<String, Object>>进行排序
     *
     */
List<Map<String, Object>> dataList = new List<Map<String, Object>>();

    class ComparatorListSort implements Comparator<Map> {
        private String orderByKey;
        public ComparatorListSort(String orderByKey){
            this.orderByKey= orderByKey;
        }
        @Override
        public int compare(Map o1, Map o2) {
            int order = 0;
            long d1 = MapUtils.getLong(o1, orderByKey, 0L);
            long d2 = MapUtils.getLong(o2, orderByKey, 0L);
            if (d1 > d2) {
                order = 1;
            } else if (d1 < d2) {
                order = -1;
            }
            return order;
        }
    }
    ComparatorListSort comparatorListSort = new ComparatorListSort("F1");
    Collections.sort(dataList,comparatorListSort);
  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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<>(); // 添加元素到listlist.sort((s1, s2) -> s1.compareTo(s2)); ``` 4. 使用Stream API:Java 8及以上版本提供了Stream API,可以方便地对集合中的元素进行排序。例如: ```java List<Integer> list = new ArrayList<>(); // 添加元素到listList<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等方式来实现。具体选择哪种方式取决于业务需求和个人偏好。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值