import java.util.*;
public class Main{
public static void main(String[] args) {
List<Integer> a = new ArrayList<>();
Random random = new Random();
for (int i = 0; i < 10; i++) {
a.add(random.nextInt(100));
}
System.out.println(a);
Collections.sort(a,new Comparator<Integer>()
{
//下面的是按照升序排列. 其中的第一个参数a代表的是实际list或者数组中后面的元素,b代表之前的元素。
//而相减之后如果为负数,比如-1,则代表两者之间的顺序要对调,
// public int compare(Integer a,Integer b){
// if(a > b) return 1; //如果后面的大于前面的,返回1的话,就代表不用调换,也就是指是按照升序排列
// else if( a < b) return -1;
// else return 0;
// }
//下面的是按照降序排列
// public int compare(Integer a, Integer b) {
// if(a > b) return -1;
// else if (a < b) return 1;
// else return 0;
// }
//升序
public int compare(Integer a, Integer b) {
return a - b; //后面减前面,如果为正数的话,代表不用交换顺序,因此也就代表是升序排列
}
//降序
// public int compare(Integer a, Integer b) {
// return b - a; //前面减后面,如果为正数,代表不用交换,也就是说前面的数大,因此也就代表是降序
// }
}
);
System.out.println(a);
//作为排序,常用的就是comparable和comparator接口。comparable中只需要实现一个compareTo函数,位于java.lang下面,而comparator位于java.util下面
List<dog> list = new ArrayList<>();
list.add(new dog("🐈", 2));
list.add(new dog("🐦", 4));
list.add(new dog("🐴", 8));
list.add(new dog("🐟", 9));
Collections.sort(list);
System.out.println(list);
}
}
class dog implements Comparable<dog>{
String name;
int age;
public dog(String name , int age){
this.name = name;
this.age = age;
}
@Override
public int compareTo(dog o) {
return this.age - o.age; // 升序 [🐈:2, 🐦:4, 🐴:8, 🐟:9]
//return o.age - this.age; // 降序 [🐟:9, 🐴:8, 🐦:4, 🐈:2]
}
@Override
public String toString(){
return this.name + ":"+this.age;
}
}