利用Set集合去除List集合中重複元素、字符串中的重複子串

Set集合特點:

① 一次只存一個元素,

② 不能存儲重複的元素

③ 存儲順序和取出來的順序不一定一致不能存儲重複的元素

可以利用②這一特點,完成去重的功能。

一:Set集合去掉List集合中重複元素

public static void main(String[] args) {
	
	//利用set集合 去除ArrayList集合中的重複元素
	ArrayList<String> list = new ArrayList<>();
	list.add("1");
    list.add("1");
    list.add("2");
    list.add("2");
    list.add("3");
    list.add("3");
    list.add("4");
    list.add("4");
    System.out.println("去重前的List集合:"+list);
    
	Set<String> set = new HashSet<>();
	set.addAll(list);
	System.out.println("Set集合:"+set);
	
	list.clear();            // 清空原有元素 放入被list去重後的元素
	list.addAll(set);
	System.out.println("去重後的List集合:"+list);
}

運行結果:

去重前的List集合:[1, 1, 2, 2, 3, 3, 4, 4]
Set集合:[1, 2, 3, 4]
去重後的List集合:[1, 2, 3, 4]

二:Set集合去掉字符串中重複子串

public static void main(String[] args) {
	String str = "aaab";
	System.out.println("字符串aaab 有非空子串a, b, aa, ab, aaa, aab, aaab,一共 7 個");
	
	Set<String> set = new HashSet<String>();
	for (int step = 0; step <= str.length() - 1; step++) {
		//掃描全部子串
		for (int begin = 0, end = 1 + step; end <= str.length(); begin++, end++) {     
			String kid = str.substring(begin, end);   //截取字符串子串
			set.add(kid);			//將子串放入set集合,完成去重
		}
	}
	System.out.println("去除重複子串後的全部子串有:"+set.size()+"個");
	System.out.println("分別是:" + set);
}

運行結果:

字符串aaab 有非空子串a, b, aa, ab, aaa, aab, aaab,一共 7 個
去除重複子串後的全部子串有:7個
分別是:[aa, aaa, a, ab, b, aab, aaab]
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章