Arrays.sort()深入理解

一维数组的排序

       int[] b = new int[]{-1, -2, -3, -4, -5};
          Arrays.sort(b);

二维数组对行整体排序

            int [][] nums1 =new int[][]{{-3,3},{-1,2},{2,9},{-1,1}};
               Arrays.sort(nums1,new Comparator<int[]>(){//对行整体排序//(a-b)->(a[1]-b[1])
            public int compare(int[] a,int[] b){
                return a[1]-b[1];//冒泡升序
            }
        });
        for(int i = 0;i<4;i++)
        System.out.println(Arrays.toString(nums1[i]));

对象数组的排序

package Test09;
import java.util.*;
public class Test {
    public static void main(String args[]) {
        Student []students = new Student[]{new Student("yang",10),new Student("huang",2),new Student("yang",8)};
        Arrays.sort(students, new Comparator<Student>() {//这里需要注意的是,比较器与compareTo(),比较器优先
            @Override
            public int compare(Student o1, Student o2) {
                if(!o1.name.equals(o2.name))
                    return o1.name.compareTo(o2.name);//冒泡升序
                return o1.age-o2.age;//冒泡升序
            }
        });
        System.out.println(Arrays.toString(students));

    }
}
class Student implements Comparable<Student>{
    String name;
    int age;
    Student(String name,int age){
        this.name = name;
        this.age = age;
    }
    @Override
    public String toString(){
        return name+" "+age;
    }

    @Override
    public int compareTo(Student o2) {//这里相当于c++重载运算符<
        if(!name.equals(o2.name))
            return o2.name.compareTo(name);//冒泡降序
        return age-o2.age;//冒泡升序
    }
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值