關於位異或運算的妙用

來源:互聯網
上載者:User

上一篇日誌談到了位操作。

 

關於位操作符:

(1)、~取反~0011 = 1100

(2)、&位與0011 & 0110 = 0010

(3)、|位或0011 | 0110  = 0111

(4)、^異或0011 ^ 0110 = 0101

 

 

有兩道題關於位異或(^)運算的妙用:

一、已知長度為2n+1的數組,數組中每個數都出現兩次,只有一個數x是單獨出現的。求出這個單獨出現的數x?

首先,說個知識點:a ^ a = 0; 0 ^ x = x;

所以,解法就是把數組所有的數做異或操作,a1^a2···x··· = 0 ^ x = x;

 

二、已知一個數組a[10000],從中拿出一個數x後,得到b[9999],求x的值?空間複雜度要求是O(1)。

解:

a1^a2···a10000 = b1^b2···b9999^x;

a1^a2···a10000^b1^b2···b9999 = b1^b2···b9999^x^b1^b2···b9999 = 0^x = x; 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.