习题汇总

习题2.65

当x有偶数个1时输出1,否则输出0。

代码:

 测试数据:

0=00000000

3=00000011

167=10100111

243=11110011

原理:

在假设int有32位的情况下,第一次异或的结果得出每两位1的个数的奇偶性,以末两位为例,若末两位为偶数个1,则得数最后一位为0,以此类推;

同理第二次异或得出每四位1的个数的奇偶性,以末四位为例,若末四位为偶数个1,则得数最后一位为0,以此类推;

......

五次异或后,最后一位得出所有32位的1的奇偶性,若有偶数个1,最后一位为0,否则为1,将得数与1异或为返回值。

 

 
 

习题3.66


由题假设: CNT=A;

struct a_struct{

int idx;

int x[B];

}

 

c代码可得:

n=*bp+*(bp+4+4A(B+1))

ap=bp+4+4(B+1)i

ap->idx=*(bp+4+4(B+1)i)

ap->x[ap->idx]=bp+4+4(B+1)i+4+4·*(bp+4+4(B+1)i)=n

 

另反汇编代码可得:

5   i->eax

6   bp->ecx

7   28i->ebx

8   8i->edx

9   7i->edx

10  *(28i+bp+4)+7i->edx

11  *(bp+200)->eax

12  *bp+*(bp+200) ->eax

13  eax->*(edx·4+bp+8)

 

可轻易看出反汇编代码12行对应c代码第9行,反汇编代码13行对应c代码11行。

 

故综上可得:

4A(B+1)+4=200且4(B+1)=28

故A=7,B=6。

posted on 2015-11-21 13:14  20135222  阅读(183)  评论(0编辑  收藏  举报

导航