1.代码如下:
package com.qingfeng.ArrayList;
import java.util.*;
import java.util.stream.Collectors;
/**
* @author:wfj
* @since: 2020/6/11
*/
public class getSameElement {
public static void main(String[] args) {
//获取list集合里出现的重复元素及出现次数
//1.结合HashMap来实现,key保存值,value保存这个值出现的次数
List<String> list = new ArrayList<>();
list.add("apple");
list.add("apple");
list.add("egg");
list.add("bamboo");
list.add("bamboo");
list.add("bamboo");
list.add("tomato");
Map<String,Integer> map = new HashMap<>();
for (String item : list) {
//定义一个计数器,记录当前元素出现的次数
Integer count = 1;
//如果当前元素在map容器中已存在,计数器+1
if (map.get(item)!=null) {
count = map.get(item) + 1;
}
//往map容器里存数据
map.put(item,count);
}
for (String key : map.keySet()) {
System.out.println("元素"+key+"出现的次数为"+map.get(key));
}
System.out.println("======================");
//2.运用for循环,筛选出重复的元素,并且往新的集合里面加,新的集合可能还会出现重复的元素
List<String> sames = new ArrayList<>();
for (int i = 0; i <list.size()-1; i++) {
for (int j = i+1 ; j < list.size();j++) {
if (list.get(i).equals(list.get(j))) {
sames.add(list.get(i));
}
}
}
//去重
List<String> sames2 = sames.stream().distinct().collect(Collectors.toList());
//筛选原来集合里只出现一次的元素
List<String> ones = list.stream().filter(item -> !sames2.contains(item)).collect(Collectors.toList());
ones.stream().forEach(item -> {
System.out.println("元素"+item+"出现的次数为1");
});
System.out.println("======================");
//筛选原来集合里重复出现的元素以及出现的次数
sames2.stream().forEach(item -> {
List<String> list1 = list.stream().filter(entity -> entity == item).collect(Collectors.toList());
System.out.println("元素"+item+"出现的次数为"+list1.size());
});
}
}
2.运行结果。