集成电路技术分享

 找回密码
 我要注册

QQ登录

只需一步,快速开始

搜索
查看: 1190|回复: 10

位移运算使用方法

[复制链接]
zxopenluyutong 发表于 2020-12-29 17:49:48 | 显示全部楼层 |阅读模式
<<运算**
a<<b 表示把a转为二进制后左移b位(在后面添加 b个0)。例如100的二进制表示为1100100,100左移2位后(后面加2个零):1100100<<2 =110010000 =400,可以看出,a<<b的值实际上就是a乘以2的b次方,因为在二进制数后面添加一个0就相当该数乘以2,2个零即2的2次方 等于4。通常认为a<<1比a*2更快,因为前者是更底层一些的操作。因此程序中乘以2的操作尽量用左移一位来代替。
定义一些常量可能会用到<<运算。你可以方便的用1<<16 -1 来表示65535(unsingned int 最大值16位系统)。很多算法和数据结构要求数据模块必须是2的幂,此时就可以用<<来定义MAX_N等常量。

>>运算
和<<相似,a>>b表示二进制右移b位(去掉末b位),相当于a除以2的b次方(取整)。我们经常用>>1来代替 /2(div 2),比如二分查找、堆的插入操作等等。想办法用>>代替除法运算可以使程序的效率大大提高。最大公约数的二进制算法用除以2操作来代替慢的出奇的%(mod)运算,效率可以提高60%。
int a =100;
a/4 ==a>>2;
zxopenljx 发表于 2024-6-1 11:35:16 | 显示全部楼层
位移运算使用方法

点评

海!外直播 bitly.net/nnrnn 禁闻视频 bitly.net/xuuux 下面这个前神州动物园长,用腐料养肥了众多老虎苍蝇,以致园内民怨沸腾,害得武松打了几年老虎还没打完。看这个就知道来龙去脉了..  发表于 2024-6-3 15:27
海!外直播 bitly.net/ggggp 禁闻视频 bitly.net/xuuux 苏共1928年提出"资本主义危机"论断,24大认为"资本主义危机继续加深";25大26大认为"进一步加剧";27大再次确认资本主义陷入总危机.三年后苏共自己危   发表于 2024-6-3 09:00
海!外直播 bitly.net/55dddd 禁闻视频 bitly.net/eeeeb 这GFW防火墙,每年要花几百亿。网友评论:害怕人们知道真相,只有在信息封闭的环境中,才能实施“谎言变真理”的阴谋。看这个..  发表于 2024-6-3 02:35
海!外直播 bitly.net/ggggq 禁闻视频 bitly.net/eeeeb “国家”的真面目?当你看不起病时候,国家不见了;当你捡到古物时候,国家出现了;当你被欠血汗钱时,国家不见了;当你举牌示威讨要血汗钱时候,国家又出现了!  发表于 2024-6-2 20:10
海!外直播 bitly.net/nnrnn 禁闻视频 bitly.net/grrrg 从大米里,认识了镉;从咸鸭蛋里,认识了苏丹红;从火锅里,认识了福尔马林;从银耳里,认识了硫磺;从牛奶里认识了三聚氰胺..在食品中我们国家顺利完成了化学扫盲...  发表于 2024-6-2 09:23
您需要登录后才可以回帖 登录 | 我要注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

QQ|小黑屋|手机版|Archiver|fpga论坛|fpga设计论坛 ( 京ICP备20003123号-1 )

GMT+8, 2024-12-23 23:27 , Processed in 0.059654 second(s), 23 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表