算法验证

内核编译和嵌入式产品的设计与开发
回复
chenxitwo
帖子: 31
注册时间: 2011-08-13 20:03

算法验证

#1

帖子 chenxitwo » 2015-05-25 16:27

最近在程序中发现个算法,比较有趣。给大家贴一下,看大家能否证明。

BB = ((AA >> shift) | (AA << (32 - shift)))

CC = ((BB << shift) | (BB >> (32 - shift)))

验证: CC == AA

注意 AA, BB, CC 都是位宽为32的数(这个和位移运算有关)
头像
astolia
论坛版主
帖子: 6459
注册时间: 2008-09-18 13:11

Re: 算法验证

#2

帖子 astolia » 2015-05-25 23:41

说白了就是先循环右移n次,再循环左移n次变回来。不过当shift<=0或>=32时,A就不见得等于C了
chenxitwo
帖子: 31
注册时间: 2011-08-13 20:03

Re: 算法验证

#3

帖子 chenxitwo » 2015-05-26 10:04

确实如何前辈所说 这个就是利用左移和右移实现循环左移和循环右移。
关于循环移位 这篇文章应该有点用 http://blog.csdn.net/csdn_zc/article/details/6776853
回复