如何判斷一個(gè)整數(shù)的二進(jìn)制中有多少個(gè)1
// 判斷一個(gè)整數(shù)的二進(jìn)制位中有多少個(gè)1
void totalOne(int x)
{
int count = 0;
while(x)
{
x = x & ( x - 1 );
count++;
}
printf("count = %d/n", count);
}
循環(huán): x = x & ( x - 1 ); count++; 直到x為0為止。該方法的時(shí)間復(fù)雜度是O(m)
在此,不妨把x的二進(jìn)制位表示為
x=an-1an-2...a0。
按從低位到高位的順序,不失一般性,假設(shè)x的第i位為第一個(gè)為1的二進(jìn)制位,即:ai=1。此時(shí)有:
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
之后重復(fù)同樣操作,直到x的二進(jìn)制位中沒有1為止
從上面可以看出,每執(zhí)行過一次 x & (x-1) 后,都會(huì)將x的二進(jìn)制位中為1的最低位的值變?yōu)?,并記數(shù)加1。
目前而言,一個(gè)整數(shù)最大64bit,所有三種方法執(zhí)行起來(lái)都可以認(rèn)為是0(1)。
上一篇:用C實(shí)現(xiàn)添加和讀取配置文件函數(shù)
欄 目:C語(yǔ)言
下一篇:深入探討:宏、內(nèi)聯(lián)函數(shù)與普通函數(shù)的區(qū)別
本文標(biāo)題:如何判斷一個(gè)整數(shù)的二進(jìn)制中有多少個(gè)1
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/4449.html
您可能感興趣的文章
- 01-10c語(yǔ)言 跳臺(tái)階問題的解決方法
- 01-10如何判斷一個(gè)數(shù)是否為2的冪次方?若是,并判斷出來(lái)是多少次方
- 01-10如何判斷一個(gè)數(shù)是否為4的冪次方?若是,并判斷出來(lái)是多少次方
- 01-10如何查看進(jìn)程實(shí)際的內(nèi)存占用情況詳解
- 01-10如何尋找數(shù)組中的第二大數(shù)
- 01-10數(shù)組中求第K大數(shù)的實(shí)現(xiàn)方法
- 01-10解析如何在C語(yǔ)言中調(diào)用shell命令的實(shí)現(xiàn)方法
- 01-10如何用C語(yǔ)言去除字符串兩邊的空字符
- 01-10判斷整數(shù)序列是否為二元查找樹的后序遍歷結(jié)果的解決方法
- 01-10如何用C語(yǔ)言生成簡(jiǎn)單格式的xml


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
- 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
- 04-02c語(yǔ)言用函數(shù)寫分段 用c語(yǔ)言表示分段
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
- 04-02c語(yǔ)言編寫函數(shù)冒泡排序 c語(yǔ)言冒泡排
- 04-02c語(yǔ)言沒有round函數(shù) round c語(yǔ)言
- 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
- 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
隨機(jī)閱讀
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10delphi制作wav文件的方法