leetcode350. 两个数组的交集 II
生活随笔
收集整理的這篇文章主要介紹了
leetcode350. 两个数组的交集 II
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
給定兩個數(shù)組,編寫一個函數(shù)來計算它們的交集。
示例 1:
輸入: nums1 = [1,2,2,1], nums2 = [2,2]
輸出: [2,2]
示例 2:
輸入: nums1 = [4,9,5], nums2 = [9,4,9,8,4]
輸出: [4,9]
說明:
輸出結(jié)果中每個元素出現(xiàn)的次數(shù),應(yīng)與元素在兩個數(shù)組中出現(xiàn)的次數(shù)一致。
我們可以不考慮輸出結(jié)果的順序。
進階:
如果給定的數(shù)組已經(jīng)排好序呢?你將如何優(yōu)化你的算法?
如果?nums1?的大小比?nums2?小很多,哪種方法更優(yōu)?
如果?nums2?的元素存儲在磁盤上,磁盤內(nèi)存是有限的,并且你不能一次加載所有的元素到內(nèi)存中,你該怎么辦?
思路:相似題:leetcode349. 兩個數(shù)組的交集
但是這個題set解決不了問題了。用map記錄出現(xiàn)的次數(shù)即可。
class Solution {public int[] intersect(int[] nums1, int[] nums2) {if (nums1.length > nums2.length) {return intersect(nums2, nums1);}HashMap<Integer, Integer> m = new HashMap<>();for (int n : nums1) {m.put(n, m.getOrDefault(n, 0) + 1);}int k = 0;for (int n : nums2) {int cnt = m.getOrDefault(n, 0);if (cnt > 0) {nums1[k++] = n;m.put(n, cnt - 1);}}return Arrays.copyOfRange(nums1, 0, k);} }?
總結(jié)
以上是生活随笔為你收集整理的leetcode350. 两个数组的交集 II的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 编译原理end
- 下一篇: redis——HyperLogLog