刷题力扣349-两个数组的交集(两个数组的交集 ii)

createh54个月前 (02-01)技术教程84

这道题代码随想录用的是哈希数据结构,什么时候用哈希表,哈希表都是用来快速判断一个元素是否出现在集合里,相对于枚举的话,哈希表的时间复杂度只有O(1)。

常见的三种哈希结构

数组

set(集合)

map(映射)

当出现快速判断一个元素是否出现在集合里的时候,就要考虑哈希法,牺牲空间换取时间。

题目描述:

题意:给定两个数组,编写一个函数来计算它们的交集。



说明: 输出结果中的每个元素一定是唯一的。 我们可以不考虑输出结果的顺序。

在不考虑数量的情况下,假设数据有无穷大,我们可以用set的哈希结构去解这道题。在java中使用set,可以得到一个不包含重复元素的集合,而且set无序,且允许出现null元素。

set方法:

boolean add(E e) //如果 set 中尚未存在指定的元素,则添加此元素(可选操作)。
boolean addAll(Collection c) //如果 set 中没有指定 collection 中的所有元素,则将其添加到此 set 中(可选操作)。
void   clear() //移除此 set 中的所有元素(可选操作)。
boolean contains(Object o) //如果 set 包含指定的元素,则返回 true。
boolean containsAll(Collection c) //如果此 set 包含指定 collection 的所有元素,则返回 true。
boolean equals(Object o) //比较指定对象与此 set 的相等性。
int    hashCode() //返回 set 的哈希码值。
boolean isEmpty() //如果 set 不包含元素,则返回 true。
Iterator iterator() //返回在此 set 中的元素上进行迭代的迭代器。
boolean remove(Object o) //如果 set 中存在指定的元素,则将其移除(可选操作)。
boolean removeAll(Collection c) //移除 set 中那些包含在指定 collection 中的元素(可选操作)。
boolean retainAll(Collection c) //仅保留 set 中那些包含在指定 collection 中的元素(可选操作)。
int    size() //返回 set 中的元素数(其容量)。
Object[] toArray() //返回一个包含 set 中所有元素的数组。
 T[] toArray(T[] a) //返回一个包含此 set 中所有元素的数组;返回数组的运行时类型是指定数组的类型。


解题思路:

将nums1的集合元素放到一个set集合里,然后去遍历nums2集合元素,如果nums2集合元素在set集合里出现,我们就可以把该元素的下标放到结果的set集合里。set集合存放的其实就是一个下标与元素的映射关系。

代码:

class Solution {
public int[] intersection(int[] nums1, int[] nums2) {
if(nums1 == null || nums1.length == 0 || nums2 == null || nums2.length == 0){
return new int[0];
}
Set set1 = new HashSet<>(); //用于存放nums1的元素
Set resSet = new HashSet<>(); //用于存放交集的元素
for(int i : nums1){
set1.add(i);
}
for(int i : nums2){
if(set1.contains(i)){ //如果nums2的元素在set1中出现,把该元素下标放到resSet集合中
resSet.add(i);
}
}
//将结果集合转为数组-法一
return resSet.stream().mapToInt(x->x).toArray();

//将结果集合转为数组-法二
int[] resArr = new int[resSet.size()];
int index = 0;
for(int i : resSet1){
resArr[index++] = i;
}

return resArr;
}

力扣这道题后来把数据范围限制在1000以内,那么可以用数组来写,java如果用数组做哈希结构的话,代码方法如下:

class Solution {
public int[] intersection(int[] nums1, int[] nums2) {
if(nums1 == null || nums1.length == 0 || nums2 == null || nums2.length == 0){
return new int[0];
}
int[] hash = new int[1005];
Set resSet = new HashSet<>(); //存放结果是为了去重
for(int i : nums1){ //对于nums1中出现过的元素,在hash数组中做记录
hash[i] = 1;
}
for(int i : nums2){
if(hash[i] == 1){
resSet.add(i);
}
}
int[] result = new int[resSet.size()];
int index = 0;
for(int i : resSet){
result[index++] = i;
}
return result;
}
}

相关文章

java程序员必备的基础知识之数组的定义和使用

如果希望保存一组有相同类型的数据,可以使用数组。数组的定义和内存分配Java 中定义数组的语法有两种: type arrayName[]; type[] arrayName;type 为Java中的任...

Java学习之数组——java基础篇(java数组知识)

如果希望保存一组有相同类型的数据,可以使用数组。数组的定义和内存分配Java 中定义数组的语法有两种: type arrayName[]; type[] arrayName;type 为Java中的任...

灵魂拷问:如何检查 Java 数组中是否包含某个值?

作者 | 沉默王二责编 | Elle在逛 programcreek 的时候,我发现了一些专注细节但价值连城的主题。比如说:如何检查Java数组中是否包含某个值 ?像这类灵魂拷问的主题,非常值得深入地研...

算法:有序数组的平方(Java版)(java 有序数组)

有序数组的平方题目描述:给定一个按非递减顺序排序的整数数组 nums,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。示例:输入: nums = [-4,-1,0,3,10] 输出: [0,1...

Java数组详解(java数组操作方法)

数组,也叫Array,是由同一种数据类型按照一定的顺序排列的集合,给这个数组起一个名字。是一种数据类型。定义数组,在类型的后面加一个[]定义数组有两种方式①静态初始化 int[] num=new in...

全新Java入门到架构师教程之Java15数组案例实现和Arrays

上篇文章写了《全新Java入门到架构师课程之Java15编程基础-数组(1):数组声明、初始化、数组元素的界限和遍历》,这次将接下去说java15编程之数组案例实现和Arrays一、数组基本练习//A...