Arrays.sort可以对所有实现Comparable的对象进行排序。但如果有多种排序需求,如有时候需对name进行降序排序,有时候只需要对年龄进行排序。使用Comparable无法满足这样的需求。可以编写不同的Comparator来满足多样的排序需求。
1.编写PersonSortable2类
属性:private name(String)、private age(int)
有参构造函数:参数为name,age
toString方法:返回格式name-age
2 编写Comparator类
编写NameComparator类,实现对name进行升序排序
编写AgeComparator类,对age进行升序排序
3.main方法中
输入n
输入n行name age,并创建n个对象放入数组
对数组按照name进行升序排序后输出。
在3的基础上对数组按照age进行升序排序后输出。
最后最后两行使用如下代码输出NameComparator与AgeComparator所实现的所有接口。
System.out.println(Arrays.toString(NameComparator.class.getInterfaces()));
System.out.println(Arrays.toString(AgeComparator.class.getInterfaces()));
输入样例:
5
zhang 15
zhang 12
wang 14
Wang 17
li 17
输出样例:
NameComparator:sort
Wang-17
li-17
wang-14
zhang-15
zhang-12
AgeComparator:sort
zhang-12
wang-14
zhang-15
Wang-17
li-17
//最后两行是标识信息
import java.util.*;
class PersonSortable2 {
String name;
int age;
public PersonSortable2(String name,int age){
this.name=name;
this.age=age;
}
@Override
public String toString() {
return name+'-'+age;
}
}
class NameComparator implements Comparator<PersonSortable2>{
@Override
public int compare(PersonSortable2 o1, PersonSortable2 o2) {
return o1.name.compareTo(o2.name);
}
}
class AgeComparator implements Comparator<PersonSortable2>{
@Override
public int compare(PersonSortable2 o1, PersonSortable2 o2) {
return o1.age-o2.age;
}
}
public class Main{
public static void main(String args[]) {
Scanner in = new Scanner(System.in);
int m=in.nextInt();
ArrayList<PersonSortable2> p=new ArrayList<>();
for (int i=0;i<m;i++){
String name=in.next();
int age=in.nextInt();
p.add(new PersonSortable2(name,age));
}
p.sort(new NameComparator());
System.out.println("NameComparator:sort");
for(PersonSortable2 i:p) System.out.println(i.toString());
p.sort(new AgeComparator());
System.out.println("AgeComparator:sort");
for(PersonSortable2 i:p) System.out.println(i.toString());
System.out.println(Arrays.toString(NameComparator.class.getInterfaces()));
System.out.println(Arrays.toString(AgeComparator.class.getInterfaces()));
}
}