二進位操作 尋找落單的數字 Single Number Leetcode #136 精選75題

2023/09/25閱讀時間約 2 分鐘
raw-image

題目在這裡:

題目敘述

題目會給定一個陣列,每個數字都恰好出現兩次,只有一個數字是例外。

要求我們找出那個落單也就是例外的數字。


測試範例

Example 1:

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

Example 2:

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

Example 3:

Input: nums = [1]
Output: 1

約束條件

Constraints:

  • 1 <= nums.length <= 3 * 10^4

輸入陣列長度介於1~三萬。

  • -3 * 10^ <= nums[i] <= 3 * 10^4

陣列元素值介於 負三萬 ~ 三萬

  • Each element in the array appears twice except for one element which appears only once.

每個元素都恰好出現兩次,只有一個例外出現一次。


演算法

除了傳統的字典(雜湊表)去紀錄出現次數的做法以外,
其實還可以利用XOR對稱相消的特性來計算出答案。

Self-inverse :

A ⊕ A = 0

所有出現兩次的數字,再經過XOR計算後,都會剛好消去等於零。

只有落單、出現一次的那個數字,會殘留在最後的計算結果,也就是我們的最終答案。


程式碼

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