查詢陣列中只出現一次的元素

2021-07-05 11:15:08 字數 363 閱讀 7050

問題:已知乙個特殊陣列,陣列中除去乙個元素只出現一次之外,其他元素都出現了兩次,現在要找出這個唯一乙個只出現了一次的資料元素,並將其列印出來。

分析:利用異或運算的特殊性。例如a異或b得到c,c再與b異或則又會得到a,那麼依照這個規律,將整個陣列逐個元素異或,最後得到的結果既是該陣列中僅出現了一次的元素。

以已知data陣列為例:

#include 

using

namespace

std;

int data[20] = ;

int findnumber(int data,int length)

int main()

陣列中只出現一次

首先看看題目要求 陣列a中,除了某乙個數字 x之外,其他數字都出現了三次,而 x出現了一次。請給出最快的方法找到x。這個題目非常有意思,在本人部落格中有 位操作基礎篇之位操作全面總結 這篇文章介紹了使用位操作的異或來解決 陣列中其他數字出現二次,而x出現一次,找出x。有 這邊文章介紹了分組異或的方法...

陣列中只出現一次的數字

何海濤 劍指offer 名企面試官精講典型程式設計題 九度oj 題目描述 乙個整型陣列裡除了兩個數字之外,其他的數字都出現了兩次。請寫程式找出這兩個只出現一次的數字。輸入 每個測試案例包括兩行 第一行包含乙個整數n,表示陣列大小。2 n 10 6。第二行包含n個整數,表示陣列元素,元素均為int。輸...

陣列中只出現一次的數字

來自劍指offer 分析 如果整型陣列中只有乙個數字出現一次,我們只需將陣列中每個元素依次做異或操作,最終就得到了只出現一次的數字。因為自己與自己異或後,結果為0.現在,陣列中有兩個數字只出現一次,上述一次遍歷後將所有元素異或得不到那兩個數字。因此,我們試著將原陣列分成兩個子陣列,使每個子陣列中分別...