java获取List「String」中重复的元素和出现次数

将重复的元素和其重复的次数放入map

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class test{
	public static void main(String[] args){
		List<String> allParent = new ArrayList<>();
		Map<String,Integer> repeatmap = new HashMap<>();
			allParent.add("钢铁侠");
			allParent.add("美队");
			allParent.add("钢铁侠");
			allParent.add("钢铁侠");
			allParent.add("绿巨人");
			allParent.add("美队");
			allParent.add("惊奇大妈");
 	    	  	if(allParent.size()>0) {
		           for (String parent : allParent) {
				       Integer count = 1;
					   if (repeatmap.get(parent)!=null) {
		                   count = repeatmap.get(parent) + 1;
		                }
					repeatmap.put(parent,count);
			       }
				   System.out.println(repeatmap.toString());
				}
	}
	
}

在这里插入图片描述

### 回答1: 可以使用Java 8的流(Stream)和Lambda表达式来获取List重复数据。下面是一些示例代码: 1. 找到所有重复元素: ```java List<String> list = Arrays.asList("A", "B", "C", "A", "D", "B"); List<String> duplicates = list.stream() .collect(Collectors.groupingBy(Function.identity(), Collectors.counting())) .entrySet().stream() .filter(e -> e.getValue() > 1) .map(Map.Entry::getKey) .collect(Collectors.toList()); System.out.println(duplicates); // 输出 [A, B] ``` 这段代码首先使用`groupingBy`方法将元素分组,然后使用`filter`方法过滤出出现次数大于1的元素,并使用`map`方法将`Map.Entry`转换为其键值,最后将结果收集到一个List。 2. 找到第一个重复元素: ```java List<String> list = Arrays.asList("A", "B", "C", "A", "D", "B"); Optional<String> firstDuplicate = list.stream() .filter(new HashSet<>()::add, HashSet::new) .findFirst(); System.out.println(firstDuplicate.orElse(null)); // 输出 A ``` 这段代码首先创建了一个空的HashSet,然后使用`filter`方法过滤出第一个无法添加到HashSet元素,即为第一个重复元素。最后使用`findFirst`方法获取结果。注意,由于结果可能为null,因此使用`Optional`类包装结果。 希望这可以帮助到你! ### 回答2: 在Java 8,我们可以使用 Stream API 来获取 List 重复数据。 首先,我们将 List 转换为 Stream 对象,然后使用 `Collectors.groupingBy` 方法对元素进行分组,相同的元素将会分到同一组。 接着,我们使用 Stream 对分组结果进行过滤,筛选出有多个元素的组,即为重复的数据。 最后,我们将过滤出的组的键值提取出来,即为 List 重复数据。 下面是一个示例代码: ```java import java.util.Arrays; import java.util.List; import java.util.Map; import java.util.stream.Collectors; public class Main { public static void main(String[] args) { List<Integer> list = Arrays.asList(1, 2, 3, 2, 4, 5, 4, 6); List<Integer> duplicates = list.stream() .collect(Collectors.groupingBy(e -> e, Collectors.counting())) .entrySet() .stream() .filter(entry -> entry.getValue() > 1) .map(Map.Entry::getKey) .collect(Collectors.toList()); System.out.println("List 重复数据:" + duplicates); } } ``` 运行代码后输出结果为:List 重复数据:[2, 4] ,即 List 重复元素是 2 和 4。 ### 回答3: 要获取一个Java 8List重复数据,可以按照以下步骤进行操作: 1. 创建一个HashMap对象,该对象的键是List元素,值是元素出现次数。 2. 使用Java 8的stream()方法将List转换为Stream。 3. 使用forEach()方法对Stream元素进行迭代。 4. 在迭代,使用HashMap的merge()方法将元素作为键,并将其值初始化为1,如果已存在相同的键,则将其值加1。 5. 创建一个新的ArrayList对象,用于存储重复元素。 6. 再次使用stream()方法将List转换为Stream。 7. 使用filter()方法对Stream元素进行过滤,根据HashMap键对应的值是否大于1来判断是否为重复元素。 8. 使用collect()方法将Stream的过滤出的元素收集到ArrayList。 9. 最后,你可以打印或做其他操作,来验证获取重复元素是否正确。 以下是一个示例代码: ``` import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; public class Main { public static void main(String[] args) { List<Integer> list = new ArrayList<>(); list.add(1); list.add(2); list.add(3); list.add(2); list.add(4); list.add(1); Map<Integer, Integer> countMap = new HashMap<>(); list.stream().forEach(num -> countMap.merge(num, 1, Integer::sum)); List<Integer> duplicates = list.stream() .filter(num -> countMap.get(num) > 1) .collect(Collectors.toList()); System.out.println("重复元素:" + duplicates); } } ``` 这个示例代码将会输出:重复元素:[1, 2]。它会将List重复元素找到,并存储在新的ArrayList对象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值