腦筋急轉彎 找出消失的數字 與 重複的數字 Set Mismatch_Leetcode #645

更新於 發佈於 閱讀時間約 4 分鐘

題目敘述

題目會給定一個整數陣列nums,原本裡面包含有整數1到n,但是中間不小心出了差錯,導致有一個數字消失了,而另一個數字重複了

找出重複的數字以及消失的數字,並且

以陣列的形式[重複的數字, 消失的數字]返回這兩個數字。

例如:

[1,3,3,4]

消失的數字是2,重複的數字是3

答案返回[3, 2]


題目的原文敘述


測試範例

Example 1:

Input: nums = [1,2,2,4]
Output: [2,3]

Example 2:

Input: nums = [1,1]
Output: [1,2]

約束條件

Constraints:

  • 2 <= nums.length <= 10^4

輸入陣列的長度介於2~10^4 之間。題目保證陣列長度至少為2。

  • 1 <= nums[i] <= 10^4

每個陣列元素值介於1 ~ 10^4 之間。


演算法

除了第一直覺的字典統計出現次數的演算法之外。

還有一個偏向數學推理的演算法。


題目說 有一個數字消失有一個數字重複

所以,

理想中(沒有出錯)的總和 perfect sum = 1 + 2 + ... + n

= 數列和公式 = 1 * (n+1) / 2


第一步:

perfect sum - 輸入陣列中曾經出現過的數字(相當與建立集合set的動作)總和

= 消失的數字

到這一步,就已經找到消失的數字


第二步:

接下來,

理想中(沒有出錯)的總和 perfect sum + 重複的數字

= 1 + 2 + ... + n + 重複的數字

= { 1 * (n+1) / 2 } + 重複的數字

= (有出錯的)輸入陣列的總和 + 消失的數字

剛剛第一步已經知道消失的數字,而pefect sum透過數列和公式可以直接求出,輸入陣列的總和也只要直接相加就可以知道。

現在未知項是重複的數字,這邊只要做個簡單的加減法計算就可以得到重複的數字


最後,以陣列的形式[重複的數字, 消失的數字]返回答案即可。


程式碼

class Solution:
def findErrorNums(self, nums: List[int]) -> List[int]:

# get the size of input array, nums

n = len(nums)

# perfect_sum
# = n * ( n+1 ) // 2
# = sum of unique element + missing element

perfect_sum = n * (n+1) // 2

# compute the missing element from summation formula

missing_element = perfect_sum - sum( set(nums) )

# perfect sum + repeated element = sum of nums + missing element
# compute the repeated element

repeated_element = sum(nums) + missing_element - perfect_sum

return [ repeated_element, missing_element]



複雜度分析

時間複雜度:

從頭到尾掃描過每個元素,建立集合 和 計算數列和,所需時間為O(n)。

空間複雜度:

建立集合set(nums),所需空間為O(n)


關鍵知識點

從數字應該出現一次的標準答案 1 + 2 + 3 + ... + n

聯想到可以用數列和的公式求出,並且推理出消失的數字重複的數字是誰。


Reference:

[1] Set Mismatch - LeetCode

avatar-img
91會員
425內容數
由有業界實戰經驗的演算法工程師, 手把手教你建立解題的框架, 一步步寫出高效、清晰易懂的解題答案。 著重在讓讀者啟發思考、理解演算法,熟悉常見的演算法模板。 深入淺出地介紹題目背後所使用的演算法意義,融會貫通演算法與資料結構的應用。 在幾個經典的題目融入一道題目的多種解法,或者同一招解不同的題目,擴展廣度,並加深印象。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
這題也算是Leetcode 上經典的DP考題之一,也是很好的DP邏輯思考練習題。 題目敘述 題目會給我們一個nums陣列,分別代表每棟房屋的價值,也就是房屋內有的現金數量。 題目敘述給的情境是假想盜賊要偷東西,限制是相鄰的兩棟房屋不能一起偷,只能選擇其中一棟,否則就會觸發警報器。 請問怎麼選
題目敘述 題目會給我們一個二維陣列matrix,分別代表每個格子的成本,請問我們從最頂端到底部的下墜路徑的最小成本總和是多少? 每次下墜到下一排的時候,可以有三種選擇: 1.往左下角移動。 2.往正下方移動。 3.往右下角移動。 題目的原文敘述 測試範例 Example 1:
題目敘述 題目會給定一個整數陣列arr,要求我們判斷是否每個元素的出現次數都不同? 題目的原文敘述 測試範例 Example 1: Input: arr = [1,2,2,1,1,3] Output: true Explanation: The value 1 has 3 occurre
題目敘述 題目會給我們一組定義好的界面和需求,要求我們設計一個資料結構,可以滿足平均O(1)的插入元素、刪除元素、隨機取得元素的操作。 RandomizedSet() 類別建構子 bool insert(int val) 插入元素的function界面 bool remove(int val
題目敘述 題目會給定我們一個比賽紀錄陣列matches,裡面以pair的方式儲存,每個pair的第一個欄位代表這場比賽的贏家ID,第二個欄位代表這場比賽的輸家ID。 題目要求我們找出所有沒有輸的玩家ID,和只輸一場的玩家ID。 計算時,只考慮有比賽紀錄的玩家。 輸出時,依照遊戲玩家的ID,從
題目敘述 題目會給定我們兩個字串word1 和 word2。 允許我們不限制次數進行下列兩種操作: 任意調換其中兩個字元的位置。 把字串中的某個字元全部置換成另一個字元,同時把另一個字元同時置換成某個字元。(例如把字串中原本的a都換成b,把原本的b都換成a) 問我們能不能通過上述兩項操作,
這題也算是Leetcode 上經典的DP考題之一,也是很好的DP邏輯思考練習題。 題目敘述 題目會給我們一個nums陣列,分別代表每棟房屋的價值,也就是房屋內有的現金數量。 題目敘述給的情境是假想盜賊要偷東西,限制是相鄰的兩棟房屋不能一起偷,只能選擇其中一棟,否則就會觸發警報器。 請問怎麼選
題目敘述 題目會給我們一個二維陣列matrix,分別代表每個格子的成本,請問我們從最頂端到底部的下墜路徑的最小成本總和是多少? 每次下墜到下一排的時候,可以有三種選擇: 1.往左下角移動。 2.往正下方移動。 3.往右下角移動。 題目的原文敘述 測試範例 Example 1:
題目敘述 題目會給定一個整數陣列arr,要求我們判斷是否每個元素的出現次數都不同? 題目的原文敘述 測試範例 Example 1: Input: arr = [1,2,2,1,1,3] Output: true Explanation: The value 1 has 3 occurre
題目敘述 題目會給我們一組定義好的界面和需求,要求我們設計一個資料結構,可以滿足平均O(1)的插入元素、刪除元素、隨機取得元素的操作。 RandomizedSet() 類別建構子 bool insert(int val) 插入元素的function界面 bool remove(int val
題目敘述 題目會給定我們一個比賽紀錄陣列matches,裡面以pair的方式儲存,每個pair的第一個欄位代表這場比賽的贏家ID,第二個欄位代表這場比賽的輸家ID。 題目要求我們找出所有沒有輸的玩家ID,和只輸一場的玩家ID。 計算時,只考慮有比賽紀錄的玩家。 輸出時,依照遊戲玩家的ID,從
題目敘述 題目會給定我們兩個字串word1 和 word2。 允許我們不限制次數進行下列兩種操作: 任意調換其中兩個字元的位置。 把字串中的某個字元全部置換成另一個字元,同時把另一個字元同時置換成某個字元。(例如把字串中原本的a都換成b,把原本的b都換成a) 問我們能不能通過上述兩項操作,
你可能也想看
Google News 追蹤
Thumbnail
大家好,我是woody,是一名料理創作者,非常努力地在嘗試將複雜的料理簡單化,讓大家也可以體驗到料理的樂趣而我也非常享受料理的過程,今天想跟大家聊聊,除了料理本身,料理創作背後的成本。
Thumbnail
哈囉~很久沒跟各位自我介紹一下了~ 大家好~我是爺恩 我是一名圖文插畫家,有追蹤我一段時間的應該有發現爺恩這個品牌經營了好像.....快五年了(汗)時間過得真快!隨著時間過去,創作這件事好像變得更忙碌了,也很開心跟很多厲害的創作者以及廠商互相合作幫忙,還有最重要的是大家的支持與陪伴🥹。  
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
終於把這部想看已久的電影補上了! 隨著萊莉邁入青春期,腦內的情緒變得更加豐富,但也變得更加敏感……?相比前一集,此次的故事線我認為更能引起共鳴。畢竟,誰都曾經歷過迷惘焦慮的青少年時期。 下面會分享我從電影中得到,關於情緒及覺察自己的想法。請繼續看下去吧!
這篇是接續上一篇,成為一個「獨立且完整」的人的第二篇,針對「完整」的人的想法。
Thumbnail
皮克斯動畫《腦筋急轉彎》中五種情緒對我們生活的重要性,通過理解與接受情緒,我們能更好地應對世界的挑戰。文章指出,情緒本身沒有好壞之分,我們要學會認識和擁抱自己的情緒,並從中獲得啟發。通過接受悲傷與挫折,調整自我認知,最終能達到更真實的自我,這是每個人一生中都應該學習的課題。
Thumbnail
只有我經歷過焦慮的時刻,我才能真正的對於別人的焦慮感同身受。這次短暫的經歷,煎熬、辛苦,但值得!
Thumbnail
分享一個猜數字的遊戲題目,給予提示讓玩家找出正確的四位數密碼。
Thumbnail
大家好,我是woody,是一名料理創作者,非常努力地在嘗試將複雜的料理簡單化,讓大家也可以體驗到料理的樂趣而我也非常享受料理的過程,今天想跟大家聊聊,除了料理本身,料理創作背後的成本。
Thumbnail
哈囉~很久沒跟各位自我介紹一下了~ 大家好~我是爺恩 我是一名圖文插畫家,有追蹤我一段時間的應該有發現爺恩這個品牌經營了好像.....快五年了(汗)時間過得真快!隨著時間過去,創作這件事好像變得更忙碌了,也很開心跟很多厲害的創作者以及廠商互相合作幫忙,還有最重要的是大家的支持與陪伴🥹。  
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
終於把這部想看已久的電影補上了! 隨著萊莉邁入青春期,腦內的情緒變得更加豐富,但也變得更加敏感……?相比前一集,此次的故事線我認為更能引起共鳴。畢竟,誰都曾經歷過迷惘焦慮的青少年時期。 下面會分享我從電影中得到,關於情緒及覺察自己的想法。請繼續看下去吧!
這篇是接續上一篇,成為一個「獨立且完整」的人的第二篇,針對「完整」的人的想法。
Thumbnail
皮克斯動畫《腦筋急轉彎》中五種情緒對我們生活的重要性,通過理解與接受情緒,我們能更好地應對世界的挑戰。文章指出,情緒本身沒有好壞之分,我們要學會認識和擁抱自己的情緒,並從中獲得啟發。通過接受悲傷與挫折,調整自我認知,最終能達到更真實的自我,這是每個人一生中都應該學習的課題。
Thumbnail
只有我經歷過焦慮的時刻,我才能真正的對於別人的焦慮感同身受。這次短暫的經歷,煎熬、辛苦,但值得!
Thumbnail
分享一個猜數字的遊戲題目,給予提示讓玩家找出正確的四位數密碼。