java判断两个集合是否有交集
时间: 2024-11-09 22:20:21 浏览: 27
在Java中,我们可以使用多种方法来判断两个集合是否有交集。以下是几种常见的方法:
1. **使用`Intersection`方法**:如果你的集合实现了`Set`接口,并且它们不是null,可以简单地调用`intersection()`方法,如下面的示例所示:
```java
Set<Integer> setA = new HashSet<>(Arrays.asList(1, 2, 3));
Set<Integer> setB = new HashSet<>(Arrays.asList(2, 4, 5));
Set<Integer> intersection = setA.intersection(setB); // 如果有交集则不会返回null
if (intersection.isEmpty()) {
System.out.println("两个集合没有交集");
} else {
System.out.println("两个集合有交集:" + intersection);
}
```
2. **使用`containsAll`和`addAll`方法**:也可以通过检查第一个集合是否能完全包含第二个集合的所有元素来间接找到交集,如果添加完整个第二集合后第一个集合还是原来的大小,则说明无交集:
```java
List<Integer> listA = new ArrayList<>(Arrays.asList(1, 2, 3));
List<Integer> listB = new ArrayList<>(Arrays.asList(2, 4, 5));
// 使用add方法尝试将listB的元素加到listA,如果没有交集,listA会保持不变
boolean hasIntersection = listA.containsAll(listB);
if (!hasIntersection) {
System.out.println("两个列表没有交集");
} else {
System.out.println("两个列表有交集");
}
```
3. **遍历比较**:最基础的方式是遍历其中一个集合,检查每个元素是否存在于另一个集合中:
```java
List<Integer> listA = Arrays.asList(1, 2, 3, 4);
List<Integer> listB = Arrays.asList(2, 5, 6);
for (Integer i : listA) {
if (listB.contains(i)) {
System.out.println("两个列表有交集:" + i);
}
}
```
阅读全文