ArrayList沒(méi)有封裝好的去重方法,比如對(duì)于一個(gè)[2, 5, 2, 3, 2, 4]的ArrayList,我要去除其中的重復(fù)的元素,
我也不想把語(yǔ)句也這么長(zhǎng),也不想用for循環(huán)的方法去重,那么可以先考慮把ArrayList轉(zhuǎn)化為一個(gè)臨時(shí)的HashSet,再把這個(gè)臨時(shí)的HashSet轉(zhuǎn)化回ArrayList,因?yàn)镠ashSet里面的元素是不可重復(fù)的嘛!至于什么是ArrayList與HashSet,在《詳解java中的Collections類》已經(jīng)說(shuō)得很清楚了,這里不再贅述。
你可以這樣寫:
HashSet<Integer> hashset_temp = new HashSet<Integer>(arraylist);
arraylist = new ArrayList<Integer>(hashset_temp);
也可以寫得更加簡(jiǎn)潔,連那個(gè)臨時(shí)的hashset_temp變量都不要了:
arraylist = new ArrayList<Integer>(new HashSet<Integer>(arraylist));
之后,ArrayList的元素變?yōu)閇2, 3, 4, 5]
下面再為大家分享ArrayList去重的兩種方法
//去重復(fù)方法一
private ArrayList RemoveDuplicateNum(ArrayList list) { list.Sort(); for (int i = 0; i < list.Count - 1; i++) { if (list[i].Equals(list[i + 1])) { list.RemoveAt(i);//去重復(fù)項(xiàng) i--; } } return list; }//去重復(fù)方法二
private ArrayList RemoveSame(ArrayList list) { //上面寫的那句是多余的,這個(gè)是最終的 for (int i = 0; i < list.Count - 1; i++) { for (int j = i + 1; j < list.Count; j++) { if (list[i].Equals(list[j])) { list.RemoveAt(j); j--; } } } return list; }以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。
新聞熱點(diǎn)
疑難解答
圖片精選