java 排序调用

import java.util.*;

/**
 * @ClassName CollectionTest
 * @Description To
 * @Author BlazeJack
 * @Date 2019/9/10 10:51
 * @Version 1.0
 **/

class MyIntCom implements Comparator{
    public int compare(Object o1, Object o2) {
     Integer a = (Integer) o1;
        Integer b = (Integer) o2;
        //小于返回-1,个人认为是前面减去后面
        if(a<= b){
            return -1;
        }
        return 1;
    }
}
public class CollectionTest {
    public static  String check(List <Integer>list){
        int len = list.size();
        for(int i = 1; i < len; i++){
            Integer a = list.get(i-1);
            Integer b = list.get(i);
            if( a> b){
                return "false";
            }
        }
        return "true";
    }
    public static void main(String[] args) {
        {
            List<Integer> num = new ArrayList();
            Random random = new Random();
            int size =10000;
            for(int i = 0; i < size; i++){
                num.add(random.nextInt(size));
            }
            System.out.println(num);
            Collections.sort(num,new MyIntCom());
//            Collections.sort(num );
            System.out.println(num);
            System.out.println(check(num));
        }

    }
}

 

Java 中,可根据不同的场景调用自带的排序功能,以下是几种常见情况: ### 对 `List` 排序Java 8 开始,`List` 接口新增了 `sort` 方法,可直接传入比较器。以下是示例代码: ```java import java.util.ArrayList; import java.util.List; public class ListSortExample { public static void main(String[] args) { List<String> words = new ArrayList<>(); words.add("apple"); words.add("banana"); words.add("cherry"); words.add("date"); // 默认升序 words.sort(String::compareTo); System.out.println("默认排序后:" + words); // 自定义排序(按长度降序) words.sort((a, b) -> b.length() - a.length()); System.out.println("按长度降序排序后:" + words); } } ``` 在上述代码里,`words.sort(String::compareTo)` 运用默认的比较器对列表进行升序排序;`words.sort((a, b) -> b.length() - a.length())` 则使用自定义比较器按字符串长度降序排序 [^1]。 ### 对数组排序 使用 `Arrays.sort` 方法对数组排序。若要对自定义对象数组排序,需传入一个 `Comparator`。如下代码对 `Person` 对象按年龄从小到大排序: ```java import java.util.Arrays; import java.util.Comparator; class Person { int age; public Person(int age) { this.age = age; } } public class ArraySortExample { public static void main(String[] args) { Person[] personArray = {new Person(25), new Person(20), new Person(30)}; Arrays.sort(personArray, new Comparator<Person>() { @Override // 按年龄从小到大排序 public int compare(Person o1, Person o2) { return o1.age - o2.age; } }); } } ``` 在这个例子中,`Arrays.sort` 方法接收 `personArray` 和一个自定义的 `Comparator` 对象,该 `Comparator` 实现了按年龄从小到大排序的逻辑 [^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Blaze Jack

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值