zoukankan      html  css  js  c++  java
  • 350. Intersection of Two Arrays II

    Given two arrays, write a function to compute their intersection.

    Example 1:

    Input: nums1 = [1,2,2,1], nums2 = [2,2]
    Output: [2,2]
    

    Example 2:

    Input: nums1 = [4,9,5], nums2 = [9,4,9,8,4]
    Output: [4,9]

    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?
    //HashMap Approach: Time: O(n), Space:O(n)  
      public int[] intersect(int[] nums1, int[] nums2) {
            if (nums1 == null || nums1.length == 0 || nums2 == null || nums2.length == 0) {
                return new int[0];
            }
            
            List<Integer> result = new ArrayList<Integer>();
            HashMap<Integer, Integer> map = new HashMap<Integer, Integer>();
            
            for (int i = 0; i < nums1.length; i++) {
                if (!map.containsKey(nums1[i])) {
                    map.put(nums1[i], 1);
                } else {
                    map.put(nums1[i], map.get(nums1[i]) + 1);
                }
            }
            
            for (int i = 0; i < nums2.length; i++) {
                if (map.containsKey(nums2[i])) {
                    result.add(nums2[i]);
                    map.put(nums2[i], map.get(nums2[i]) - 1);
                    
                    if (map.get(nums2[i]) == 0) {
                        map.remove(nums2[i]);
                    }
                }
            }
            
            int[] ans = new int[result.size()];
            
            for (int i = 0; i < result.size(); i++) {
                ans[i] = result.get(i);
            }
            
            return ans;
        }
    //Two pointer approach: Time: O(nlogn), Space: O(1)
    //这种方法和349. Intersection of Two Arrays的区别是用一个用set hold结果,一个用list hold结果
        public int[] intersect(int[] nums1, int[] nums2) {
            if (nums1 == null || nums1.length == 0 || nums2 == null || nums2.length == 0) {
                return new int[0];
            }
            
            Arrays.sort(nums1);
            Arrays.sort(nums2);
            
            List<Integer> result = new ArrayList<Integer>();
            int i = 0; 
            int j = 0;
            
            while (i < nums1.length && j < nums2.length) {
                if (nums1[i] == nums2[j]) {
                    result.add(nums1[i]);
                    i++;
                    j++;
                } else if (nums1[i] < nums2[j]) {
                    i++;
                } else {
                    j++;
                }
            }
            
            int[] ans = new int[result.size()];
            
            for (int k = 0; k < result.size(); k++) {
                ans[k] = result.get(k);
            }
            
            return ans;
        }
  • 相关阅读:
    命令行打开无线网络设置
    WebView2 的使用记录
    QT-Mac:在Mac下实现QT程序的打包及公证
    QT:CEF实现js函数与C++函数的异步调用
    QT-Mac:QT Creator 中QT Versions显示无效的QT版本的解决办法
    QT-Mac: Undefined symbols for architecture x86_64
    全局键盘钩子失效与WebRTC的关系分析
    第十二届蓝桥杯决赛 大学 B 组 C/C++ 做题记录
    Luogu P2671 求和 | 数学奇偶性&前缀和
    2021铁三决赛 PWN cardstore | 格式化字符串 & ret2libc
  • 原文地址:https://www.cnblogs.com/jessie2009/p/9774507.html
Copyright © 2011-2022 走看看