整数的二进制中有多少个1 怎样判断一个整数的二进制中有多少个1

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

整数的二进制中有多少个1 怎样判断一个整数的二进制中有多少个1

  2021-03-18 我要评论
想了解怎样判断一个整数的二进制中有多少个1的相关内容吗,在本文为您仔细讲解整数的二进制中有多少个1的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:判断,整数,二进制,下面大家一起来学习吧。
复制代码 代码如下:

// 判断一个整数的二进制位中有多少个1
void totalOne(int x)
{
 int count = 0;
 while(x)
 {
  x = x & ( x - 1 );
  count++;
 }
 printf("count = %d/n", count);
}

循环: x = x & ( x - 1 ); count++; 直到x为0为止。该方法的时间复杂度是O(m)
在此,不妨把x的二进制位表示为
          x=an-1an-2...a0。
按从低位到高位的顺序,不失一般性,假设x的第i位为第一个为1的二进制位,即:ai=1。此时有:
          x       =an-1an-2...ai+1100...0              <1>
         (x-1)  =an-1an-2...ai+1011...1              <2>
很明显,从式1和式2可以得出,在第一次 x & (x-1) 后:
          x=an-1an-2...ai+1000...0
之后重复同样操作,直到x的二进制位中没有1为止
从上面可以看出,每执行过一次 x & (x-1) 后,都会将x的二进制位中为1的最低位的值变为0,并记数加1。
目前而言,一个整数最大64bit,所有三种方法执行起来都可以认为是0(1)。

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们