伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

三种方法判断二进制中1的个数

来源:本站原创 浏览:132次 时间:2022-01-10

余数方法(最简单,最易理解的算法):

#include <stdio.h>int main(){int i, n;int count = 0;scanf_s("%d", &n);while (n){if (n % 2 == 1){count++;}n = n / 2;}printf("%d\n", count);}


但是如果为负数结果就很难预料:
修改为无符号类型则可以解决这个问题:

#include <stdio.h>int can(unsigned int n){int count = 0;while (n){if (n % 2 == 1){count++;}n = n / 2;}return count;}int main(){int i, n;int count = 0;scanf_s("%d", &n);i=can(n);printf("%d\n",i );}


位操作方法(难度中):

通过移位操作和1作比较,将两个数进行位运算,结果位1则计数一次反正不执行。

#include <stdio.h>int main(){int i, a;int count = 0;scanf_s("%d", &a);for (i = 0; i < 32; i++){if (((a >> i) & 1) == 1)                                       {count++;}}printf("%d\n", count);}

通过一个算法判断程序执行次数推断1的个数:(执行效率最高)

#include <stdio.h>int main(){int i, n;int count = 0;scanf_s("%d", &n);while (n){n = n & (n - 1);count++;}printf("%d\n", count);}

算法:n=n&(n-1):
输入:13
//1101    n     13
&
//1100    n-1   12
//1100    赋值给n   12
&
//1011    n-1       11
//1000     n       8
&
//0111    n-1    7
//0000
运算一次则让最右边少1,直到全为0为止就可以了。
注:本次程序在VS2019中测试。

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net