LeetCode Intersection of Two Arrays II
原题链接在这里:https://leetcode.com/problems/intersection-of-two-arrays-ii/
题目:
Given two arrays, write a function to compute their intersection.
Example:
Given nums1 = [1, 2, 2, 1], nums2 = [2, 2], return [2, 2].
Note:
- Each element in the result should appear as many times as it shows in both arrays.
- The result can be in any order.
Follow up:
- What if the given array is already sorted? How would you optimize your algorithm?
- What if nums1's size is small compared to nums2's size? Which algorithm is better?
- What if elements of nums2 are stored on disk, and the memory is limited such that you cannot load all elements into the memory at once?
题解:
可以使用双指针.
Time Complexity: O(nlogn). Space: O(1).
AC Java:
 public class Solution {
     public int[] intersect(int[] nums1, int[] nums2) {
         Arrays.sort(nums1);
         Arrays.sort(nums2);
         int i = 0;
         int j = 0;
         List<Integer> res = new ArrayList<Integer>();
         while(i<nums1.length && j<nums2.length){
             if(nums1[i] < nums2[j]){
                 i++;
             }else if(nums1[i] > nums2[j]){
                 j++;
             }else{
                 res.add(nums1[i]);
                 i++;
                 j++;
             }
         }
         int [] resArr = new int[res.size()];
         int k = 0;
         for(int num : res){
             resArr[k++] = num;
         }
         return resArr;
     }
 }
Could use HashMap as well.
Time Complexity: O(m + n).
Space: O(Math.min(m, n)).
AC Java:
 class Solution {
     public int[] intersect(int[] nums1, int[] nums2) {
         if(nums1 == null || nums2 == null){
             return new int[0];
         }
         HashMap<Integer, Integer> hm = new HashMap<>();
         for(int num : nums1){
             hm.put(num, hm.getOrDefault(num, 0) + 1);
         }
         List<Integer> res = new ArrayList<>();
         for(int num : nums2){
             if(hm.containsKey(num)){
                 res.add(num);
                 if(hm.get(num) == 1){
                     hm.remove(num);
                 }else{
                     hm.put(num, hm.get(num) - 1);
                 }
             }
         }
         int [] resArr = new int[res.size()];
         int i = 0;
         for(int num : res){
             resArr[i++] = num;
         }
         return resArr;
     }
 }
Follow up 2 nums1 length is smaller. 用双指针先sort两个array明显没有利用到num1.length小的特性. 若是用HashMap来记录num1每个element出现频率再iterate nums2, 那么Time Complexity: O(m + n), m = nums1.length, n = num2.length. Space: O(m).
或者sort nums1 再对每一个num2的element在 sorted nums1上做 binary search. Time Complexity: O(mlogm + nlogm). Space: O(1).
由此可见,当m很小时,用HashMap和binary search就是time和space的trade off.
Follow up 3 nums2 is sorted but too big for memory. I/O的操作很贵,所以首先想到的是避免I/O的次数。
若是nums1可以全部load到memory上, 先sort nums1再把nums2从小到大分开load到memory来.
if load进来这一段最大值, 也就是最后一个值<nums1[0] 或者 load进来这一段最小值, 也就是第一个值>nums1[nums1.length-1]可以直接跳过, load下一段. else load进来这一段 和 sorted nums1做双指针.
若是nums1也太大了,就先external sort nums1, 在分开load进来nums1一段和nums2一段做双指针.
类似Find Common Characters, Intersection of Two Arrays.
LeetCode Intersection of Two Arrays II的更多相关文章
- [LeetCode] Intersection of Two Arrays II 两个数组相交之二
		Given two arrays, write a function to compute their intersection. Example:Given nums1 = [1, 2, 2, 1] ... 
- [LeetCode] 349 Intersection of Two Arrays && 350 Intersection of Two Arrays II
		这两道题都是求两个数组之间的重复元素,因此把它们放在一起. 原题地址: 349 Intersection of Two Arrays :https://leetcode.com/problems/in ... 
- 26. leetcode 350. Intersection of Two Arrays II
		350. Intersection of Two Arrays II Given two arrays, write a function to compute their intersection. ... 
- LeetCode Javascript实现 169. Majority Element 217. Contains Duplicate(两个对象比较是否相等时,如果都指向同一个对象,a==b才是true)350. Intersection of Two Arrays II
		169. Majority Element /** * @param {number[]} nums * @return {number} */ var majorityElement = funct ... 
- 【leetcode】350. Intersection of Two Arrays II
		problem 350. Intersection of Two Arrays II 不是特别明白这道题的意思,例子不够说明问题: 是按顺序把相同的元素保存下来,还是排序,但是第二个例子没有重复... ... 
- [LeetCode] Intersection of Two Arrays 两个数组相交
		Given two arrays, write a function to compute their intersection. Example:Given nums1 = [1, 2, 2, 1] ... 
- LeetCode Intersection of Two Arrays
		原题链接在这里:https://leetcode.com/problems/intersection-of-two-arrays/ 题目: Given two arrays, write a func ... 
- [LintCode] Intersection of Two Arrays II 两个数组相交之二
		Given two arrays, write a function to compute their intersection.Notice Each element in the result s ... 
- LeetCode_350. Intersection of Two Arrays II
		350. Intersection of Two Arrays II Easy Given two arrays, write a function to compute their intersec ... 
随机推荐
- Xshell5连接虚拟机出现连Could not connect to '192.168.47.128' (port 22): Connection failed,解决办法
			该日记写于2016年11月28日.在用Xshell5连接ubuntu虚拟OS时一直连接不上.出现这种情况的原因可能很多,有像百度上面说的没有关闭linux的防火墙,没有启动linux的ssh服务.但这 ... 
- static lib和dynamic lib
			lib分为 staticlib 和 dynamic lib: 静态lib将导出声明和实现都放在lib中,编译后所有代码都嵌入到宿主程序, 链接器从静态链接库LIB获取所有被引用函数,并将库同代码一起放 ... 
- FTP协议及工作原理
			1. FTP协议 什么是FTP呢?FTP 是 TCP/IP 协议组中的协议之一,是英文File Transfer Protocol的缩写. 该协议是Internet文件传送的基础,它由一系列规格说明文 ... 
- Dubbo详细介绍与安装使用过程
			今天看到一篇不错的dubbo介绍教程,原文链接:http://blog.csdn.net/xlgen157387/article/details/51865289 1 Dubbo介绍 1.1 dubb ... 
- 2016"百度之星" - 资格赛(Astar Round1)
			逆元 1001 Problem A 求前缀哈希和逆元 #include <bits/stdc++.h> typedef long long ll; const int MOD = 9973 ... 
- Codeforces525E Anya and Cubes(双向搜索)
			题目 Source http://codeforces.com/contest/525/problem/E Description Anya loves to fold and stick. Toda ... 
- 用介个新的blog咯..
			之前csdn实在是太卡了.. 只要一写比较长的blog就卡的要死.. 转过来这吧,比较好吧.. 原blog地址 啊为啥域名叫darklove呢.. 这是很久之前创建的.. 简单来说是一个和clearl ... 
- uva10986 堆优化单源最短路径(pas)
			var n,m,s,t,v,i,a,b,c:longint;//这道题的代码不是这个,在下面 first,tr,p,q:..]of longint; next,eb,ew:..]of longint; ... 
- HDU1559 最大子矩阵  (二维树状数组)
			题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1559 最大子矩阵 Time Limit: 30000/10000 MS (Java/Others) ... 
- jQuery的封装方式与JS中new的实现原理
			function jQuery() { return new jQuery.fn.init(); } jQuery.fn = jQuery.prototype = { init: function() ... 
