第一種方法,也是比較容易想到的,就是模2除2法。模2運算得到這個數二進位制序列中的最低位,除2去掉這個數二進位制序列中的最低位。當這個數進行模2運算的結果為1時,那麼它的最低位就是1,然後再進行除2運算,將倒數第二位的數置為最末位,如此迴圈,當這個數為0時,也就判斷完了每一位是否為1。同時應該注意,這個方法只能判斷正數,不能判斷負數,因為負數進行模2運算的結果只能是0,這是這個方法的一大缺陷。下面是具體實現**:
#define _crt_secure_no_warnings 1
#include
#include
//模2除2法,該方法不能判斷負數,因為負數模2的結果總是0
int count_one_bits(int n)
n = n / 2;//除2可以去掉最末位的數
}return count;
}int main()
第二種方法,是將這個數與1進行按位與,如果結果是1,那麼這個數的最末位就是1,判斷完最末位,再將這個數進行右移運算,判斷倒數第二位,如此迴圈32次,就判斷出了這個數二進位制序列中有多少個數字1。這個方法彌補了模2除2法只能判斷正數的缺陷。下面是具體實現**:
#define _crt_secure_no_warnings 1
#include
#include
int count_one_bits(int n)
}return count;
}int main()
第三種方法,也是最優化的一種方法,即將要判斷的數和這個數減一的數進行按位與再賦給這個數,然後如此迴圈,直到這個數為0,這樣就可以判斷除這個數二進位制序列中具體有多少個數字1。 具體實現**如下:
#define _crt_secure_no_warnings 1
#include
#include
int count_one_bits(int n)
return count;
}int main()
三種方法實現求二進位制中1的個數
問題 輸入乙個整數,輸出其二進位制表示中1的個數 位運算是把數字用二進位制表示後,對每一位上0或1的運算 先判斷輸入的整數最右一位是不是1 接著將整個數字右移一位,此時,原來處於從右邊數第2位的數字就成了最右一位了,再次判斷最右一位是不是1 依此類推,知道整個整數數值為0 int numberof ...
判斷乙個二進位制數的正負
計算機中,用二進位制 或者簡寫成十六進製制 表示數,高位為0的數為正數,高位為1的數是負數。例如,int a 0xf48904e,int b 0xf48904e0,long c 0xf80000000l,long d 0xf800000000000000l.其中,a和c是正數,b和d是負數 通過編寫...
判斷乙個整數二進位制下1的個數
1.最容易想到的就是 n 1 得到最後一位是不是 1 然後再將 n 1 這樣迴圈 int 32次就可以得到1的個數,但是這樣n為負數時會陷入死迴圈 2.不如換乙個思路設定乙個 i 每次讓i 1這樣就不會對n進行修改,避免了死迴圈 public static int getnum3 int n ret...