亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

求二進制中1的個數的五種方法

發布時間:2020-08-12 16:21:16 來源:網絡 閱讀:442 作者:小止1995 欄目:編程語言
#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;
}


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

文安县| 喀喇沁旗| 四子王旗| 宕昌县| 巢湖市| 阿荣旗| 德令哈市| 介休市| 常宁市| 女性| 乌拉特后旗| 山东省| 衡南县| 通州区| 宣化县| 广安市| 湛江市| 高唐县| 临邑县| 寿光市| 马鞍山市| 肥东县| 徐州市| 庆城县| 富平县| 东台市| 岚皋县| 虹口区| 黄陵县| 长沙市| 类乌齐县| 湘潭县| 安康市| 宜川县| 安义县| 安塞县| 周宁县| 蓬安县| 准格尔旗| 枝江市| 清水河县|