使用collections类对集合操作
常用方法:
- 排序集合中的元素:sort(List<T> list)
- sort(List<T> list,Comparator c)
- 反转集合中的元素:reverse((List<T> list)
- 打乱集合中元素的位置:shuffle(List<T> list)
(排序升序,使用默认的compare方法,需要自定义排序,需要重写Comparator类中的compare方法)
方法一实现:
对随机产生的10个数进行排序
public static void main(String[] args) {
ArrayList<Integer> arr = new ArrayList<Integer>();
for(int i = 0; i<10 ; i++)
arr.add((int) (Math.random()*100));
Collections.sort(arr);
System.out.println(arr);
}
方法二的实现:
用户集合进行排序:对用户的号码排序,号码相同则对用户的姓名进行排序。
如果我们使用方法一来对用户集合进行排序,由于类型不匹配,会导致编译错误。
所以我们需要通过方法二来实现该操作。
public static void main(String[] args) {
ArrayList<User> Userarr = new ArrayList<User>();
User user1 = new User(12, "Jon", "北京");
User user2 = new User(12, "Mike", "湖南");
User user3 = new User(12, "Allen", "上海");
Userarr.add(user1);
Userarr.add(user2);
Userarr.add(user3);
Collections.sort(Userarr, new Comparator<User>() {
@Override
public int compare(User o1, User o2) {
int num = o1.getNumber()-o2.getNumber();
return num == 0?o1.getName().compareTo(o2.getName()):num;
}
});
Iterator ite = Userarr.iterator();
while(ite.hasNext())
System.out.println(ite.next());
}
输出结果:
方法三的实现:
public static void main(String[] args) {
ArrayList<Integer> arrayList = new ArrayList<Integer>();
for(int i = 0;i<20;i += 2)
arrayList.add(i);
System.out.println("反转前"+arrayList);
Collections.reverse(arrayList);
System.out.println("反转后"+arrayList);
}
输出结果:
方法四的实现:
public static void main(String[] args) {
ArrayList<Integer> arrayList = new ArrayList<Integer>();
for(int i = 0;i<20;i += 2)
arrayList.add(i);
System.out.println("打乱前"+arrayList);
Collections.shuffle(arrayList);
System.out.println("打乱后"+arrayList);
}
输出结果: