输入一个非负整数num,对于每一个i,0<=i<=num,计算i的二进制表示中,有几个‘1’,例如输入num=5,输出0,1,1,2,1,2。
创新互联建站是工信部颁发资质IDC服务器商,为用户提供优质的成都西云数据中心服务
#include <iostream> using 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<<"解法一:"<<endl; for(i=0;i<=num;i++) { cout<<countOne(i)<<","; } cout<<endl; cout<<"解法二:"<<endl; for(i=0;i<=num;i++) { cout<<countOne2(i)<<","; } return 0; }
网页标题:统计一个整数二进制中1的个数
文章分享:https://www.cdcxhl.com/article26/pgjojg.html
成都网站建设公司_创新互联,为您提供商城网站、Google、企业网站制作、网站设计公司、移动网站建设、电子商务
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联