LeetCode 350. 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?
Subscribe to see which companies asked this question.

題目

計算兩個數組的交

樣例
nums1 = [1, 2, 2, 1], nums2 = [2, 2], 返回 [2, 2].

分析

這道題是上一道題的擴展,只是這次要記錄重復的元素的個數,這次我們就用一個哈希表,鍵記錄重復元素,值記錄重復個數就行了。采用hashset的方法

代碼

public class Solution {
    /**
     * @param nums1 an integer array
     * @param nums2 an integer array
     * @return an integer array
     */
    public int[] intersection(int[] nums1, int[] nums2) {
        // Write your code here
        Map<Integer, Integer> map = new HashMap<Integer, Integer>();
        for(int i = 0; i < nums1.length; ++i) {
            if (map.containsKey(nums1[i]))
                map.put(nums1[i], map.get(nums1[i]) + 1); 
            else
                map.put(nums1[i], 1);
        }

        List<Integer> results = new ArrayList<Integer>();

        for (int i = 0; i < nums2.length; ++i)
            if (map.containsKey(nums2[i]) &&
                map.get(nums2[i]) > 0) {
                results.add(nums2[i]);
                map.put(nums2[i], map.get(nums2[i]) - 1); 
            }

        int result[] = new int[results.size()];
        for(int i = 0; i < results.size(); ++i)
            result[i] = results.get(i);

        return result;
    }
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • LeetCode題目鏈接 注意:凡是以英文出現的,都是題目提供的,包括答案代碼里的前幾行。 題目: Given t...
    _Xie_閱讀 452評論 0 0
  • 目前支持的平臺有Pre.im、豌豆莢、應用寶,超簡單實現,調用DownLoadManager做下載,有什么好的建議...
    BertSir閱讀 736評論 0 5
  • 今天是我出國滿一年的日子。沒什么特別的感想,換了個地方吃飯睡覺自拍罷了。當然,能在雪地里照相,我是很高興的。 這1...
    肥杰西閱讀 1,871評論 6 24
  • 前段時間發生了一件讓我們所有人深惡痛絕的事,在山東臨沂一個18歲的女大學生名叫許玉玉,好不容易考上了南京的郵電大學...
    三個悟空閱讀 430評論 0 1
  • 書叫《慢決策:如何在極速時代掌握慢思考的力量》。 分享三部分內容: 一,延遲決策、 意思有兩個,延遲做決定的時...
    李紅燁閱讀 170評論 1 2