专注Java教育14年 全国咨询/投诉热线:444-1124-454
赢咖4LOGO图
始于2009,口口相传的Java黄埔军校
首页 学习攻略 Java中的arrays类的sort方法

Java中的arrays类的sort方法

更新时间:2020-08-03 15:05:57 来源:赢咖4 浏览3726次

Arrays.sort()方法虽然功能强大,但是在平常的使用中难免会出现各种情况使得其无法满足我们的需求,这个时候就该用到:
Arrays.sort(a,fromIndex,toIndex,c);
这种用法了
先对方法中的各项参数进行解释:
a——需要进行排序的对象
fromIndex——排序进行的起始位置
toIndex——排序的终止位置
c——自定义的排序规则
实现的代码如下:

import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
//定义类a
class a{
    int n;
}

//定义类cmp,制定排序规则
class cmp implements Comparator{

    public int compare(a A, a B) {
        if(A.n > B.n)return -1;
        if(A.n == B.n)return 0;
        if(A.n < B.n)return 1;
        return 0;
    }
}
public class Main{

    public static void main(String args[]){
        Scanner sc = new Scanner(System.in);
        while(sc.hasNext()){
            int n = sc.nextInt();
            a t[] = new a [n];
            for(int i = 0;i < n;i++){
                t[i] = new a();//为类分配内存必不可少
                t[i].n = sc.nextInt();
            }
            Arrays.sort(t,0,n,new cmp());
            for(int i = 0;i < n;i++)
                System.out.print(t[i].n+" ");
            System.out.println();
        }
    }
}

它的效果是对含有一个int型成员变量n的类a的数组按n的大小进行降序排序
在上面给出的代码中,最为关键的地方在于这一段:

//定义类cmp,制定排序规则
class cmp implements Comparator{

    public int compare(a A, a B) {
        if(A.n > B.n)return -1;
        if(A.n == B.n)return 0;
        if(A.n < B.n)return 1;
        return 0;
    }
}
在compare(

PS:如果方法的应用对象是类,那么对于每一个对象来说,这一段都是必不可少的:
t[i] = new a();//为类分配内存必不可少
以上就是赢咖4java培训机构的小编针对“Java中的arrays类的sort方法”的内容进行的回答,希望对大家有所帮助,如有疑问,请在线咨询,有专业老师随时为你服务。

提交申请后,顾问老师会电话与您沟通安排学习

免费课程推荐 >>
技术文档推荐 >>