题目描述:

/* 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. appium locator

    If you want to find out more about the UIAutomator library, then it might be helpful to check out ht ...

  2. android webview点击返回键回到上一个html

    android webview点击返回键返回上一个html @Override public boolean onKeyDown(int keyCode, KeyEvent event) { if ( ...

  3. myeclipse破解教程,对所有版本有效,完美支持32位和64位

    破解软件下载地址 执行Run.bat文件,按照以下步骤进行激活: 第一步:输入任意用户名 第二步:点击Systemid... 按钮,自动生成本机器的systemid. 第三步:点菜单Tools-> ...

  4. C++11多线程

    这篇文章说的很详细: https://www.ibm.com/developerworks/cn/linux/1412_zhupx_thread/

  5. php mysql 数据库写入与读取取文件

    近期的项目由于特殊原因,需要将文件存到数据库中.今天特地测试,首先在php网站上传文件,将文件读取出来——再存入到MySQL数据库中. 一.首先创建php 代码如下(网上找了段代码进行过修改):源代码 ...

  6. SICP 习题 (1.13) 解题总结

    SICP习题1.13要求证明Fib(n)是最接近φn/√5 的整数,其中φ=(1+√5)/2 .题目还有一个提示,提示解题者利用归纳法和斐波那契数的定义证明Fib(n)=(φn - ψn) / √5 ...

  7. lombk在IDEA中报ClassNotFoundException错误

    今天接手了一个项目,用到了lombk,第一次用到,做为纯JAVA来说,确实不错. 不过在使用中碰到了一个问题,就是在IDEA中,可以在结构中看到getter和setter等都已经正确的生成了,但是运行 ...

  8. css的repaint和reflow

    css的repaint和reflow 浏览器为了重新渲染部分或整个页面,重新计算页面元素位置和几何结构(geometries)的进程叫做 reflow. 由于 reflow 是一种浏览器中的用户拦截( ...

  9. POJ 3723 Conscription(并查集建模)

    [题目链接] http://poj.org/problem?id=3723 [题目大意] 招募名单上有n个男生和m个女生,招募价格均为10000, 但是某些男女之间存在好感,则招募的时候, 可以降低与 ...

  10. How can I get an object's absolute position on the page in Javascript?

    How can I get an object's absolute position on the page in Javascript? How can I get an object's abs ...