在C語言的學(xué)習(xí)中我們也許會(huì)遇到求一個(gè)數(shù)的二進(jìn)制序列中1的個(gè)數(shù)的題目
下面我們介紹一種相對(duì)簡(jiǎn)易的方法?
int main()
{
int i = 0;//定義一個(gè)i變量,即我們需要求二進(jìn)制形式中1的個(gè)數(shù)的數(shù)字
scanf("%d", &i);//輸入變量i的值
int count = 0;//定義一個(gè)變量以表示1的個(gè)數(shù)
while (i)
{
i = i & (i - 1);
count++;
}
printf("%d", count);//輸出
return 0;
}
考慮到&操作符的特性
我們可以選取&操作符來達(dá)到我們的目標(biāo)。
假設(shè)i的值為15,則i的二進(jìn)制序列為 1111
若給i按位與上i-1 即i&(i-1)
此時(shí)即是1111-i
?1110-(i-1)
?? ?1110-i&(i-1)
我們發(fā)現(xiàn)i最低位的1變成了0
此時(shí)我們?cè)龠M(jìn)行一遍 1110-i
??? ? ? ? ? ? ? ? ? ?1101-(i-1)
?? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?1100-i&(i-1)
我們發(fā)現(xiàn)i的1又減少了一個(gè)
那么以此類推,i每按位與一次(i-1)i的二進(jìn)制形式中就會(huì)減少一個(gè)1,而最終i的值會(huì)變成0
考慮到while循環(huán)的特性(判斷條件非0即進(jìn)入循環(huán)),我們就可以寫出上述的代碼
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級(jí)服務(wù)器適合批量采購(gòu),新人活動(dòng)首月15元起,快前往官網(wǎng)查看詳情吧
分享標(biāo)題:C語言中求一個(gè)數(shù)的二進(jìn)制序列的1的個(gè)數(shù)-創(chuàng)新互聯(lián)
網(wǎng)頁網(wǎng)址:http://vcdvsql.cn/article6/ddgjog.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、微信公眾號(hào)、營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站內(nèi)鏈、網(wǎng)站收錄、品牌網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容