位運算的題目

2021-10-13 21:51:30 字數 524 閱讀 8978

nowcoder

乙個整型陣列裡除了兩個數字之外,其他的數字都出現了兩次,找出這兩個數。

兩個不相等的元素在位級表示上必定會有一位存在不同,將陣列的所有元素異或得到的結果為不存在重複的兩個元素異或的結果。

diff &= -diff 得到出 diff 最右側不為 0 的位,也就是不存在重複的兩個元素在位級表示上最右側不同的那一位,利用這一位就可以將兩個元素區分開來。

性質:乙個2的冪次方的數(n)與(n-1)進行與運算 結果必然為0。

public

boolean

ispoweroftwo

(int n)

位運算相關題目

面試中會遇到很多與位運算相關的題目,在這裡對位運算的相關知識點和遇到的一些題目總結一下。二進位制的5種位運算 與 或 異或 左移 m 右移 m n表示 把m右移n位 最右邊的n為會被丟棄,如果數值原來是個正數,用0補上最左邊的n位,如果是乙個負數,則最左邊補上n個1 題型一 進製轉換 微軟產品exc...

位運算題目

今天看到牛客網的一些題目,非常經典。解法基本也都很熟悉,所以特地做個總結,後續慢慢補充。先上題目 數字中的二進位制有多少個1 這裡的數字並不關心它的符號,所以即便是負數,只需要得到二進位制中1的個數就可以了。但是在python中,對於負數的右移運算,符號位會保留,這樣在執行迴圈語句的右移操作時,首位...

位運算題目彙總

給你乙個整數陣列 arr 請你將陣列中的元素按照其二進位制表示中數字 1 的數目公升序排序。如果存在多個數字二進位制中 1 的數目相同,則必須將它們按照數值大小公升序排列。請你返回排序後的陣列。輸入 arr 0 1,2 3,4 5,6 7,8 輸出 0,1,2,4,8,3,5,6,7 解釋 0 是唯...