题目描述:

/* Return 1 when x contains an even number of 1s;0 otherwise. Assume W=32 */

int even_ones(unsigned x);

函数应该遵循位级整数编码规则,不过你可以假设数据类型int 有w=32位。

你的代码最多只能包含12个算术运算、位运算和逻辑运算。

代码如下:

 int even_ones(unsigned x)
{
  x = x ^ (x >> );
4   x = x ^ (x >> );
  x = x ^ (x >> );
  x = x ^ (x >> );
  x = x ^ (x >> );
  return !(x & );
}

代码分析:

我们首先用一个具体的数据来测试这段代码,比如我们用444164这个数字,444164的二进制为1101100011100000100.

第一次异或操作:

00000000000001101100011100000100

^

00000000000000110110001110000010

=

00000000000001011010010010000110

关于得出的这个结果,我们认为右起的第i位,表示原数第i位和第i+1位中包含1的奇偶情况。比如右起第0位为0,则原数第0和第1位包含1的个数为偶;而右起第1位为1,则原数第1位和第2位包含1的个数为奇。。。

为什么可以得出这个结论呢?x >> 1,我们假设这个数为x',而x'的第i位数实际上就是x的第i+1位,所以x ^ x',实际就是x的第i位与第i+1位异或,而异或的定义为相同为0,不同为1,所以如果这两位都为1或都为0,包含偶数个1,则结果为0,反之亦然。

第二次异或操作:

00000000000001011010010010000110

^

00000000000000010110100100100001

=

00000000000001001100010110100111

关于得出的这个结果,我们认为右起的第i位,表示原数第i位和第i+1,i+2,i+3位中包含1的奇偶情况。为什么能得出这样的结论?我们先看第一次操作的结果,第0位表示原数的第0和第1位的情况,第1位表示原数第1位和第2位的情况,第2位表示原数第2位和第3位的情况。。。我们假设第2次异或操作的数为x2,而x2 >> 2 的结果为 x2',这时,x2'的第0位其实是x2的第2位,所以x2 ^ x2' 实际上是x2的第i位和第i+2位的异或,而我们前面提到 第0位表示原数的第0和第1位的情况,第2位表示原数第2位和第3位的情况,所以第二次操作得出的结果的第i位是 x2的第i位和第i+2位的异或,即表示原数第i位和第i+1,i+2,i+3位中包含1的奇偶情况。

剩下的几次异或操作分析很上面类似。。。

整个操作的形式化表示如下:

1.x ^ (x >> 1)

x:   

x >> 1:

x ^ (x >> 1):

2.x ^ (x >> 2)

x:  

x >> 2:

x ^ (x >> 2):

3.x ^ (x >> 4)

x:  

x >> 4:

x ^ (x >> 4):

4.x ^ (x >> 8)

x:  

x >> 8:

x ^ (x >> 8):

5.x ^ (x >> 16)

x:  

x >> 16:

x ^ (x >> 16):

参考博客:http://www.matrix67.com/blog/archives/264

当x含有偶数个1,返回1,否则为0。的更多相关文章

  1. 判断是否含有中文,包含返回true,不包含返回false

    /** * 功能:判断是否含有中文,包含返回true,不包含返回false */ function isChina(s) { var patrn = /[\u4E00-\u9FA5]|[\uFE30- ...

  2. libusb_bulk_transfer返回值不是0

    libusb_bulk_transfer返回值不是0 libusb_bulk_transfer返回值不是0libusb_bulk_transfer返回值不是0 ?????

  3. 服务器返回数组,data[0]得到的总是不对?如何处理?

    我用asp.net MVC 写了服务器代码,返回数组,ajax怎么处理返回的数组内容? 您好,首先用eval将获得的ajax数据转化成json对象并赋值给一个变量. 比如: var obj=eval( ...

  4. spring MVC之返回JSON数据(Spring3.0 MVC)

    方式一:使用ModelAndView的contentType是"application/json" 方式二:返回String的            contentType是&qu ...

  5. [环境搭建]-Web Api搭建到IIS服务器后PUT请求返回HTTP Error 405.0 - Method Not Allowed 解决方法 转摘:http://blog.csdn.net/qiujuer/article/details/23827531

    尝试使用微软的Web Api,他的确是一个很有意思的东西. 让我体会到了许多的方便,但是我发现部署到IIS服务器上去了后PUT和Delete请求将返回405. 原因是IIS的默认处理程序默认情况下只允 ...

  6. iOS返回一个前面没有0,小数点后保留两位的数字字符串

    /* * 处理一个数字加小数点的字符串,前面无0,保留两位.网上有循环截取的方法,如果数字过长,浪费内存,这个方法在优化内存的基础上设计的. */ -(NSString*)getTheCorrectN ...

  7. 使用mysql 统计函数 结果为null时返回值改为0

    SELECT COALESCE(SUM(total),0)  FROM test_table

  8. js 返回一个数组里面0出现的次数

    var num = new Array(10000).fill('').map((item,index) => (index + 1)). 在点号后面补充代码,让num是这个数组中0出现的次数, ...

  9. [Inno Setup] 执行程序,返回值不为0时提示用户

    procedure LoadPerfCounter(); var Ret : Integer; begin if Exec(ExpandConstant('{sys}') + '\lodctr.exe ...

随机推荐

  1. linux性能监控三张图

    一.监控 二.测试 三.优化

  2. Tip插件的使用

    Tip.js概述——美化弹窗插件 开源美化弹窗插件1.JavaScript原生代码2.美化网站用户界面 Tip.js插件的显示效果 Tip.js的使用方法 Tip({ str:'alert上需要弹出显 ...

  3. 浅谈Spring(三)

    一.基础Spring的标准测试 1.导入spring与junit继承的jar 2.引入注解 @RunWith(SpringJUnit4ClassRunner.class) @ContextConfig ...

  4. kruskal算法求最小生成树(jungle roads的kruskal解法)

    注意: 注意数组越界问题(提交出现runtimeError代表数组越界) 刚开始提交的时候,边集中边的数目和点集中点的数目用的同一个宏定义,但是宏定义是按照点的最大数定义的,所以提交的时候出现了数组越 ...

  5. 巧妙实现缺角radiogroup控制多个fragment切换和滑动

    在android开发中,用一个radiogroup控制多个fragment切换是十分常见的需求.但是如果fragment是一个ListView,如何保证滑动的时候通过缺角可以看到下面的listview ...

  6. python 时间字符串与日期转化

    python 时间字符串与日期转化 datetime.datetime.strptime(string, format) 根据指定的格式解析字符串为一个datetime类型.相当于datetime.d ...

  7. 编程习题——Maximum Subarray

    Find the contiguous subarray within an array (containing at least one number) which has the largest ...

  8. MySQL 表分区A

    在MySQL中表的分区类型总的来说有四种: 第一种:range分区.基于一个给定的区间范围,把数据分配到不同的分区. 第二种:list   分区.基本枚举的值列表进行分区. 第三种:hast 分区.基 ...

  9. HelloX项目github协同开发指南

    概述 为了提高协同开发效率,HelloX项目已托管到github网站上.根据目前的开发进展,创建了下列几个子项目: HelloX操作系统内核项目:https://github.com/hellox-p ...

  10. HDU 3501 Calculation 2

    题目大意:求小于n的与n不互质的数的和. 题解:首先欧拉函数可以求出小于n的与n互质的数的个数,然后我们可以发现这样一个性质,当x与n互质时,n-x与n互质,那么所有小于n与n互质的数总是可以两两配对 ...