温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

java自带排序怎么用

发布时间:2021-12-20 10:26:36 来源:亿速云 阅读:114 作者:小新 栏目:开发技术

这篇文章主要介绍了java自带排序怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

基本类型排序:

int a[]={1,2,5,3,6,4};
Arrays.sort(a);//对a升序排序
Arrays.sort(a,0,6);//对a从下标0,到下标5排序

自定义类型排序:

static Student b[]=new Student [4];
for(int i=0;i<4;++i)b[i]=new Student("str", 4-i);
Arrays.sort(b,new Mcompeter());//对数组所有元素排序,Comparator可以用实例,也可以匿名对象
Arrays.sort(b,0,4,new Mcompeter());//对数组从下标0到3排序

static class Student {
     public String name;
     public int age;
     
     public Student(String name,int age){
        this.name = name;
        this.age = age;
     }
     
     public String toString() {
      return "Student [name=" + name + ", age=" + age + "]";
     }
}
static class Mcompeter implements Comparator<Student> 
 {
  @Override
  public int compare(Student o1, Student o2) {
   // TODO 自动生成的方法存根
   if(o1.name.compareTo(o2.name)==0)
   {
    return o1.age-o2.age;
   }
   else return o1.name.compareTo(o2.name);
  }
 }

java自带排序怎么用

比较函数的写法:

参考:https://blog.csdn.net/weixin_41922289/article/details/90463971

比较逻辑:

  • o1 < o2 ---- 返回负数

  • o1 = o2 ---- 返回 0

  • o1 > o2 ---- 返回正数

人都绕晕了。。。

理一下思路:

排序函数默认从小到大排序
那么怎么界定谁大谁小呢,给排序函数一个比较函数

那么比较函数已经有两个参数了,怎么表示o1,o2的大小关系呢?

就是逻辑如下:

o1  <  o2   ---- 返回负数
o1  =  o2   ---- 返回 0
o1  >  o2   ---- 返回正数

  • 返回负数表示o1<o2

  • 返回0 表示相等

  • 返回正数表示o1>o2

要把排序函数和比较函数分离开

他们是独立实现功能的函数,只要保证他们自己的正确即可

写比较函数需要做的就是:

  • 在o1<o2时返回负数

  • 在o1=o2时返回0

  • 在o1>o2时返回整数

其中的"<"和“>”不一定是真实数值意义上的小于和大于,而是你希望的小于和大于。

比如o1 o2都为int

if(o1>o2) return -1;

那么o1的值比o2大就是我定义的“小于”

感谢你能够认真阅读完这篇文章,希望小编分享的“java自带排序怎么用”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI