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.*;
public class Main {
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
int num = Integer.parseInt(scan.nextLine());
List<PersonSortable> list = new ArrayList<>();
for (int i=0;i<num;i++){
String str = scan.nextLine();
String[] split = str.split(" ");
list.add(new PersonSortable(split[0],Integer.parseInt(split[1])));
}
list.sort(new NameComparator());
System.out.println("NameComparator:sort");
for (PersonSortable v:list){
System.out.println(v);
}
list.sort(new AgeComparator());
//使用comparable接口实现排序
//Collections.sort(list);
System.out.println("AgeComparator:sort");
for (PersonSortable v:list){
System.out.println(v);
}
System.out.println(Arrays.toString(NameComparator.class.getInterfaces()));
System.out.println(Arrays.toString(AgeComparator.class.getInterfaces()));
}
}
class PersonSortable {
private String name;
private int age;
public String getName() {
return this.name;
}
public int getAge() {
return this.age;
}
public PersonSortable(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return name+"-"+age;
}
}
class NameComparator implements Comparator<PersonSortable>{
@Override
public int compare(PersonSortable o1, PersonSortable o2) {
return o1.getName().compareTo(o2.getName());
}
}
class AgeComparator implements Comparator<PersonSortable>{
@Override
public int compare(PersonSortable o1, PersonSortable o2) {
return o1.getAge()-o2.getAge();
}
}
//实现Comparable接口:实现先对name升序排序,如果name相同则对age进行升序排序
/*
class PersonSortable implements Comparable<PersonSortable>{
//private name(String)、private age(int)
private String name;
private int age;
public String getName() {
return this.name;
}
public int getAge() {
return this.age;
}
public PersonSortable(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return name+"-"+age;
}
@Override
public int compareTo(PersonSortable o) {
//返回值是正数,就是升序排序
//返回值是负数,就是降序排序
String name = o.getName();
int age = o.getAge();
if (this.name.equals(name)) return this.age -age;
else return this.name.compareTo(name);
}
}
*/