从品牌网站建设到网络营销策划,从策略到执行的一站式服务
输入一个非负整数num,对于每一个i,0<=i<=num,计算i的二进制表示中,有几个‘1’,例如输入num=5,输出0,1,1,2,1,2。
创新互联建站是工信部颁发资质IDC服务器商,为用户提供优质的成都西云数据中心服务
#includeusing namespace std; // 解法1 int countOne(int num) { int count = 0; while ( num ) { // 当最后一位为1时,则加1 if( num & 1 ){ ++count; } num >>= 1; } return count; } /* 解法2,比如当二进制中的1只有一个时,num & (num - 1)会等于0,以此判断即可。 * 比如: 0000 0100 * & 0000 0011 * = 0000 0000 */ int countOne2(int num) { int count = 0; while ( num ) { num &= (num - 1) ; ++count; } return count; } int main(int argc, char *argv[]) { int i,num; cout << "请输入num:" << endl; cin>>num; cout<<"解法一:"<
网站栏目:统计一个整数二进制中1的个数
标题链接:http://www.cdkjz.cn/article/pgjojg.html
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图