程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C >> C語言基礎知識 >> 如何判斷一個整數的二進制中有多少個1

如何判斷一個整數的二進制中有多少個1

編輯:C語言基礎知識
代碼如下:

// 判斷一個整數的二進制位中有多少個1
void totalOne(int x)
{
 int count = 0;
 while(x)
 {
  x = x & ( x - 1 );
  count++;
 }
 printf("count = %d/n", count);
}

循環: x = x & ( x - 1 ); count++; 直到x為0為止。該方法的時間復雜度是O(m)
在此,不妨把x的二進制位表示為
          x=an-1an-2...a0。
按從低位到高位的順序,不失一般性,假設x的第i位為第一個為1的二進制位,即:ai=1。此時有:
          x       =an-1an-2...ai+1100...0              <1>
         (x-1)  =an-1an-2...ai+1011...1              <2>
很明顯,從式1和式2可以得出,在第一次 x & (x-1) 後:
          x=an-1an-2...ai+1000...0
之後重復同樣操作,直到x的二進制位中沒有1為止
從上面可以看出,每執行過一次 x & (x-1) 後,都會將x的二進制位中為1的最低位的值變為0,並記數加1。
目前而言,一個整數最大64bit,所有三種方法執行起來都可以認為是0(1)。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved