集合操作: 尋找兩個陣列的差異值Diff of Two Arrays_Leetcode #2215 精選75題解析

2024/02/29閱讀時間約 4 分鐘

題目敘述

題目會給定我們兩個整數陣列作為輸入nums1, nums2,要求我們找出兩個陣列的差異值。

找出在nums1但是不在nums2的元素,以陣列的形式放在answer[0]輸出。

找出在nums2但是不在nums1的元素,以陣列的形式放在answer[1]輸出。

題目的原文敘述


測試範例

Example 1:

Input: nums1 = [1,2,3], nums2 = [2,4,6]
Output: [[1,3],[4,6]]
Explanation:
For nums1, nums1[1] = 2 is present at index 0 of nums2, whereas nums1[0] = 1 and nums1[2] = 3 are not present in nums2. Therefore, answer[0] = [1,3].
For nums2, nums2[0] = 2 is present at index 1 of nums1, whereas nums2[1] = 4 and nums2[2] = 6 are not present in nums2. Therefore, answer[1] = [4,6].

Example 2:

Input: nums1 = [1,2,3,3], nums2 = [1,1,2,2]
Output: [[3],[]]
Explanation:
For nums1, nums1[2] and nums1[3] are not present in nums2. Since nums1[2] == nums1[3], their value is only included once and answer[0] = [3].
Every integer in nums2 is present in nums1. Therefore, answer[1] = [].

約束條件

Constraints:

  • 1 <= nums1.length, nums2.length <= 1000

陣列nums1 和 nums2的長度都介於1 ~ 1000之間

  • -1000 <= nums1[i], nums2[i] <= 1000

每個陣列元素都介於-1000 ~ 1000之間。


演算法

看到存在性的檢查,聯想到集合set操作


題目的要求是

找出在nums1但是不在nums2的元素,以陣列的形式放在answer[0]輸出。

找出在nums2但是不在nums1的元素,以陣列的形式放在answer[1]輸出。

相當於對應的集合操作

set( nums1 ) - set( nums1 ) 交集 set( nums2 )

set( nums2 ) - set( nums1 ) 交集 set( nums2 )

以行動支持創作者!付費即可解鎖
本篇內容共 1625 字、0 則留言,僅發佈於Leetcode 精選75題 上機考面試題 詳解你目前無法檢視以下內容,可能因為尚未登入,或沒有該房間的查看權限。
45會員
288內容數
由有業界實戰經驗的演算法工程師, 手把手教你建立解題的框架, 一步步寫出高效、清晰易懂的解題答案。 著重在讓讀者啟發思考、理解演算法,熟悉常見的演算法模板。 深入淺出地介紹題目背後所使用的演算法意義,融會貫通演算法與資料結構的應用。 在幾個經典的題目融入一道題目的多種解法,或者同一招解不同的題目,擴展廣度,並加深印象。
留言0
查看全部
發表第一個留言支持創作者!