#include<iostream>
using namespace std;
//求二進制中1的個數:對于一個字節(8bit)的變量,要求算法的執行效率盡可能的高
//1,對于二進制,對2求余可得到這一位是0還是1
int count1(int v)
{
int num=0;
while(v)
{
if(v%2==1)
++num;
v=v/2;
}
return num;
}
//2.除2可用右移操作,提高效率,判斷一位是否為1可用與來判別
int count2(int v)
{
int num=0;
while(v)
{
num+=(v&1);
v>>=1;
}
return num;
}
//這個數是2的整數次冪來判斷
int count3(int v)
{
int num=0;
while(v)
{
v&=(v-1);
++num;
}
return num;
}
//4.分支語句進行判斷:效率低
int count4(int v)
{
int num=0;
switch(v)
{
case 0:
num=0;
break;
case 1:
case 2:
case 4:
case 8:
case 16:
case 32:
case 64:
case 128:
num=1;
break;
case 3:
case 6:
case 12:
//還有別的可能
num=2;
break;
}
return num;
}
//5.查表法
int countTable[256]={
0,1,1,2,1,2,
};
int count5(int v)
{
return countTable[v];
}
int main()
{
cout<<count1(3)<<endl;
cout<<count2(15)<<endl;
cout<<count3(4)<<endl;
cout<<count4(128)<<endl;
cout<<count5(0)<<endl;
return 0;
}
另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
標題名稱:求二進制中1的個數的五種方法-創新互聯
網頁鏈接:http://www.yijiale78.com/article44/dicihe.html
成都網站建設公司_創新互聯,為您提供網站設計公司、網站排名、云服務器、軟件開發、微信公眾號、品牌網站設計
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯