更新时间:2020-08-03 15:05:57 来源:极悦 浏览3885次
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();//为类分配内存必不可少
以上就是极悦java培训机构的小编针对“Java中的arrays类的sort方法”的内容进行的回答,希望对大家有所帮助,如有疑问,请在线咨询,有专业老师随时为你服务。
0基础 0学费 15天面授
Java就业班有基础 直达就业
业余时间 高薪转行
Java在职加薪班工作1~3年,加薪神器
工作3~5年,晋升架构
提交申请后,顾问老师会电话与您沟通安排学习