一集合的工具類(Collections):
筆試題:
說出Collection與Collections的區(qū)別?
1.Collection是一個(gè)單列集合跟接口,Collections是一個(gè)操作集合的工具類
Collections常見方法:
對(duì)list集合排序
sort(list);
sort(list,comparator)
對(duì)list進(jìn)行二分法查找
int binarySearch(list,key);
int binarySearch(list,key,Comparator);
按照指定比較器進(jìn)行排序
max(Collection);
max(Collection,comparator);
min(Collection);
min(Collection,comparator);
*對(duì)list集合進(jìn)行反轉(zhuǎn) *
reverse(list);
將不同步的集合變?yōu)橥降募?/em>
Set synchronizedSet(SET<t> s)
Map synchronizedMaP(Map<K,V> m)
List synchronizedList(List<T> list)
public class Test {
public static void main(String args[]){
ArrayList <Integer> list = new ArrayList<Integer>();
list.add(1);
list.add(123);
list.add(3);
list.add(12);
list.add(23);
//排序
Collections.sort(list);
System.out.println("排序后元素為:"+list);
//查找
System.out.println("找到的位置是:"+Collections.binarySearch(list, 123));
//最大值
System.out.println("最大值是:"+Collections.max(list));
//反轉(zhuǎn)
Collections.reverse(list);
System.out.println("反轉(zhuǎn)后無素為:"+list);
}
}
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
class Student{
int id;
String name;
public Student(int id,String name){
this.id = id;
this.name = name;
}
@Override
public String toString() {
// TODO Auto-generated method stub
return String.format("編號(hào):%d 姓名:%s\n",id,name);
}
}
class MyComparator implements Comparator<Student>{
@Override
public int compare(Student o1, Student o2) {
return o1.id - o2.id;
}
}
public class Demo02 {
public static void main(String[] args) {
ArrayList <Student> list = new ArrayList<Student> ();
list.add(new Student(3,"丁昌江"));
list.add(new Student(2,"熊尚旭"));
list.add(new Student(1,"吳云飛"));
//排序
Collections.sort(list,new MyComparator());
System.out.println("排序后元素為:"+list);
//查找
System.out.println("查找到的位置是:"+Collections.binarySearch(list,new Student(1,"馬云"),new MyComparator()));
/*因?yàn)楸容^器的原因,只要編號(hào)一樣就視為找到了*/
//反轉(zhuǎn)
Collections.reverse(list);//反轉(zhuǎn)是不依賴比較器的喲!
System.out.println("反轉(zhuǎn)后無素為:"+list);
}
}
二:集合的工具類Arrays:
Arrays常見方法:
二分查找:
binarySearch(int[]);
binarySearch(double[]);
數(shù)組排序
sort(int [])
sort(char[])
將數(shù)組變成字符串
toString(int []);
復(fù)制數(shù)組
copyOf(int/boolean...[] original,int newLength);
original:源數(shù)組
newLenght:新數(shù)組長度
復(fù)制部分?jǐn)?shù)組
copyOfRange(int/float[]... original, int from, int to)
比較兩個(gè)數(shù)組是否相同
equals(int[],int[]);
將數(shù)組變成集合
List asList(T[]);
public class Test02 {
public static void main(String[] args) {
int a[] = {1,3,2,6};
int b[] = Arrays.copyOf(a,4);
int c[] = Arrays.copyOfRange(a, 1, 4);
System.out.println(Arrays.toString(b));
System.out.println(Arrays.toString(c));
System.out.println("比較兩個(gè)數(shù)組:"+Arrays.equals(a, b));//true
/*兩個(gè)數(shù)組的比較,只有內(nèi)容,容量,順序一樣才是true*/
Integer[] d1= {1,2,3,4};
List list = Arrays.asList(d1);
for (int i = 0; i < list.size();i++){
System.out.println(list.get(i)+"");
}
/*
這里如果接收的是基本數(shù)據(jù)類型的數(shù)組,那么相當(dāng)于只是存儲(chǔ)了int[]這個(gè)類型,容量是1
一般是使用包裝類Integer
*/
}
}