兩個陣列的交集 II

2021-09-29 04:04:40 字數 1034 閱讀 5410

給定兩個陣列,編寫乙個函式來計算它們的交集。
示例 1:

輸入: nums1 = [1,2,2,1], nums2 = [2,2]

輸出: [2,2]

示例 2:

輸入: nums1 = [4,9,5], nums2 = [9,4,9,8,4]

輸出: [4,9]

方法一:

雜湊表,把陣列1的所有元素都放到雜湊表中,並記錄次數。然後再遍歷陣列2,看雜湊表中是否有元素,有的話看次數是否在0以上,都滿足的話就放入結果集,並把次數減1

時間複雜度為o(n) 空間複雜度為o(n)

方法二:

先把兩個陣列排序,然後定義兩個指標分別指向兩個陣列的起點,比較兩個指標下的元素大小,相同則放入結果集然後兩個指標分別向後移動一位。第乙個指標下的元素大於第二個下的元素的話,第二個指標後移一位,第乙個指標下的元素小於第二個下的元素的話,第乙個指標後移一位。

時間複雜度為o(nlogn) 空間複雜度為o(1)

ps 在陣列規模很小的時候,方法二不一定比方法一耗時長。

方法一
class solution  else 

}listanslist = new arraylist<>();

for (int value : nums2)

}int ans = new int[anslist.size()];

int idx = 0;

for (integer num : anslist)

return ans;

}}

方法二
class solution  else if (value1 > value2)  else 

}int ans = new int[anslist.size()];

int idx = 0;

for (integer value : anslist)

return ans;

}}

兩個陣列的交集 II

給定兩個陣列,寫乙個方法來計算它們的交集。例如 給定 nums1 1,2,2,1 nums2 2,2 返回 2,2 注意 思路 對於這種題型,我的第乙個思路就是遍歷nums2,看nums1中是否有元素與其相等,若相等,則投入交集陣列。但仔細想想就會發現行不通,因為陣列中會可能會有 重複元素。既然會有...

兩個陣列的交集II

給定兩個陣列,編寫乙個函式來計算它們的交集。示例 1 輸入 nums1 1,2,2,1 nums2 2,2 輸出 2,2 示例 2 輸入 nums1 4,9,5 nums2 9,4,9,8,4 輸出 4,9 說明 輸出結果中每個元素出現的次數,應與元素在兩個陣列 現的次數一致。我們可以不考慮輸出結果...

php 兩個陣列求交集 兩個陣列的交集 II

給定兩個陣列,編寫乙個函式來計算它們的交集。輸入 nums1 1,2,2,1 nums2 2,2 輸出 2,2 輸入 nums1 4,9,5 nums2 9,4,9,8,4 輸出 4,9 輸出結果中每個元素出現的次數,應與元素在兩個陣列 現次數的最小值一致。我們可以不考慮輸出結果的順序。1.將兩個陣...