当前位置:网站首页>获取list集合中重复的元素
获取list集合中重复的元素
2022-07-29 12:12:00 【妃宫千早】
方法1
List<String> words = Arrays.asList("a", "b", "c", "d", "a", "d");
List<String> results = HashMultiset.create(words).entrySet().stream()
.filter(w -> w.getCount() > 1)
.map(Multiset.Entry::getElement)
.collect(Collectors.toList());
System.out.println(results);
方法2
可以修改返回值 返回去重的集合
public static <E> List<E> getListDuplicateElements(List<E> list){
List<E> words = list;
Set<E> repeated = new HashSet<>();
List<E> results = new ArrayList<>();
for (E word : words) {
if (!repeated.add(word)) {
results.add(word);
}
}
return results;
}
方法3
导入guava依赖
<!-- https://mvnrepository.com/artifact/com.google.guava/guava -->
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>31.0-jre</version>
</dependency>
List<String> words = Arrays.asList("a", "b", "c", "d", "a", "d");
List<String> results = new ArrayList<>();
for (Multiset.Entry<String> entry : HashMultiset.create(words).entrySet()) {
if (entry.getCount() > 1) {
results.add(entry.getElement());
}
}
System.out.println(results);
Lambda 来使用guava
List<String> words = Arrays.asList("a", "b", "c", "d", "a", "d");
List<String> results = HashMultiset.create(words).entrySet().stream()
.filter(w -> w.getCount() > 1)
.map(Multiset.Entry::getElement)
.collect(Collectors.toList());
System.out.println(results);
方法4
public List getRepeatList(List list) {
List list2 = new ArrayList();
for (int i = 0; i < list.size(); i++) {
for (int j = i + 1; j < list.size(); j++) {
if (list.get(i) !="" && list.get(i).equals(list.get(j))) {
list2.add(list.get(i));
break;
}
}
}
return list2;
}
/** * 获取list 集合重复元素 * * @param list * @param <E> * @return */
public static <E> List<E> getDuplicateElements(List<E> list) {
return list.stream() .filter( i -> i!="") // list 对应的 Stream 并过滤""
.collect(Collectors.toMap(e -> e, e -> 1, Integer::sum)) // 获得元素出现频率的 Map,键为元素,值为元素出现的次数
.entrySet()
.stream() // 所有 entry 对应的 Stream
.filter(e -> e.getValue() > 1) // 过滤出元素出现次数大于 1 (重复元素)的 entry
.map(Map.Entry::getKey) // 获得 entry 的键(重复元素)对应的 Stream
.collect(Collectors.toList()); // 转化为 List
}
题外
//定义一个100元素的集合,包含A-Z
List<String> list = new LinkedList<>();
for (int i =0;i<100;i++){
list.add(String.valueOf((char)('A'+Math.random()*('Z'-'A'+1))));
}
System.out.println(list);
//统计集合重复元素出现次数,并且去重返回hashmap
Map<String, Long> map = list.stream().
collect(Collectors.groupingBy(Function.identity(),Collectors.counting()));
System.out.println(map);
//由于hashmap无序,所以在排序放入LinkedHashMap里(key升序)
Map<String, Long> sortMap = new LinkedHashMap<>();
map.entrySet().stream().sorted(Map.Entry.comparingByKey()).
forEachOrdered(e -> sortMap.put(e.getKey(), e.getValue()));
System.out.println(sortMap);
//获取排序后map的key集合
List<String> keys = new LinkedList<>();
sortMap.entrySet().stream().forEachOrdered(e -> keys.add(e.getKey()));
System.out.println(keys);
//获取排序后map的value集合
List<Long> values = new LinkedList<>();
sortMap.entrySet().stream().forEachOrdered(e -> values.add(e.getValue()));
System.out.println(values);
已逗号隔开返回字符串
String collect = name.stream().map(String::valueOf).collect(Collectors.joining(","));
过滤条件
List<Integer> collect = list.stream().filter(item -> item >= 1 && item <= 10).collect(Collectors.toList());
边栏推荐
- 宝塔快速搭建自适应咖啡网站模板与管理系统源码实测
- 【每日SQL打卡】DAY 22丨平均售价【难度中等】
- QCon大会广州站它来了!独家定制双肩背包等你领取!
- DAY 25 daily SQL clock 】 【 丨 different sex daily score a total difficulty moderate 】 【
- 【我的OpenGL学习进阶之旅】向量点乘和叉乘的几何意义
- MarkDown高阶语法手册
- DAY 27 daily SQL clock 】 【 丨 within a specified period of time all order products [difficult simple]
- AI cocoa AI frontier introduction (7.29)
- 黑马四小时入门学习记录-3|网络应用
- ECCV 2022 | 基于关系查询的时序动作检测方法
猜你喜欢
随机推荐
TiDB 操作实践 -- 备份与恢复
金仓数据库 KingbaseES 客户端编程接口指南 - ODBC 驱动使用
WordPress 编辑用户
WordPress 固定链接设置
【多线程】——Callable创建多线程
什么是DOM
金仓数据库KingbaseES安全指南--6.8. SSPI身份验证
吴恩达老师机器学习课程笔记 06 逻辑回归
Wu En 07 regularization of teacher machine learning course notes
【一起学Rust | 基础篇】Rust基础——变量和数据类型
The company has a new product, do you want to hire an agent?
【每日SQL打卡】DAY 22丨平均售价【难度中等】
宝塔快速搭建自适应咖啡网站模板与管理系统源码实测
报表查询字段集sql摘记
【Unity3D】场景切换、退出全屏、退出游戏
puzzle(017.5)联动归位
DAY 22 丨 page daily clock in SQL 】 【 recommend 【 difficulty moderate 】
基础架构之分布式配置中心
2022-07-29 Daily: The latest major progress of AlphaFold: complete almost all known protein structure predictions of more than 200 million, fully open
国内首秀元宇宙Live House圆满收官,百事可乐虚拟偶像真的好会!!