java 取交集方法retainAll的實現(xiàn)
java 取交集方法retainAll
有兩個集合newCoures和oldCourses,判斷這兩個集合是否包含相同的對象或元素,
可以使用retainAll方法:
oldCourses.retainAll(newCoures)
如果存在相同元素,oldCourses中僅保留相同的元素。
如果不存在相同元素,oldCourse會變?yōu)榭铡?/p>
如果有多個集合oldCourses1、oldCourses2、oldCourses3等,分別與newCourses比較,應(yīng)該將newCourses統(tǒng)一放在后面,像這樣:
oldCourses1.retainAll(newCoures); oldCourses2.retainAll(newCoures); oldCourses3.retainAll(newCoures);
public class Test { public static void main(String[] args) { List<String> list1 = new ArrayList<String>(); List<String> list2 = new ArrayList<String>(); List<String> list3 = new ArrayList<String>(); for (int i = 0; i < 20; i++) { list1.add(i+""); if(i%2 == 0) { list2.add(i+""); } list3.add(i+"@"); } // list1 與 list2 存在相同元素,list1集合只保留list2中存在的元素 list1.retainAll(list2); if(list1.isEmpty()) { System.out.println("不包含"); } else { System.out.println("包含"); } System.out.println(list1); // list1 與 list3 不存在相同元素,list1集合變?yōu)榭? list1.retainAll(list3); if(list1.isEmpty()) { System.out.println("不包含"); } else { System.out.println("包含"); } System.out.println(list1); } }
運行結(jié)果如下:
retainall的問題
在調(diào)用java中的retainall時遇到個問題
代碼如下:
public static ArrayList<Integer> res_and(ArrayList<Integer> s1,ArrayList<Integer> s2) { s1.retainAll(s2); // System.out.println("s1="); // System.out.println(s1); return s1;
我定義了一個函數(shù),用來求出s1和s2共有的部分,將其保存在s1中。
但是貌似這么寫會導(dǎo)致s1中重復(fù)元素會重復(fù)出現(xiàn)兩次。
解決辦法:
在返回前加上一句
s1 = new ArrayList<Integer>(new HashSet<Integer>(s1));
即可。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于TreeMap自定義排序規(guī)則的兩種方式
這篇文章主要介紹了關(guān)于TreeMap自定義排序規(guī)則的兩種方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08Java網(wǎng)絡(luò)編程之TCP程序設(shè)計
這篇文章主要為大家詳細介紹了Java網(wǎng)絡(luò)編程之TCP程序設(shè)計,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-08-08Spring boot實現(xiàn)一個簡單的ioc(1)
這篇文章主要為大家詳細介紹了Spring boot實現(xiàn)一個簡單的ioc,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04Java中的String對象數(shù)據(jù)類型全面解析
首先String不屬于8種基本數(shù)據(jù)類型,String是一個對象,因為對象的默認(rèn)值是null,所以String的默認(rèn)值也是null;但它又是一種特殊的對象,有其它對象沒有的一些特性2012-11-11詳解Java數(shù)據(jù)結(jié)構(gòu)和算法(有序數(shù)組和二分查找)
本篇文章主要介紹了詳解Java數(shù)據(jù)結(jié)構(gòu)和算法(有序數(shù)組和二分查找),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-09-09