使用Collections類對集合進行操作
阿新 • • 發佈:2020-12-11
使用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);
}
輸出結果: