找回密码
 立即注册→加入我们

QQ登录

只需一步,快速开始

搜索
热搜: 下载 VB C 实现 编写
查看: 1580|回复: 3

经典的二进制翻转

[复制链接]

9

主题

10

回帖

451

积分

用户组: 中·技术宅

UID
5181
精华
3
威望
39 点
宅币
260 个
贡献
79 次
宅之契约
0 份
在线时间
42 小时
注册时间
2019-7-25
发表于 2021-6-11 15:48:23 | 显示全部楼层 |阅读模式

欢迎访问技术宅的结界,请注册或者登录吧。

您需要 登录 才可以下载或查看,没有账号?立即注册→加入我们

×
这是jdk中的一段代码,感觉很不错,转过来,给出了c实现
  1.    /**
  2.      * Returns the value obtained by reversing the order of the bits in the
  3.      * two's complement binary representation of the specified {@code int}
  4.      * value.
  5.      *
  6.      * @param i the value to be reversed
  7.      * @return the value obtained by reversing order of the bits in the
  8.      *     specified {@code int} value.
  9.      * @since 1.5
  10.      */
  11.     public static int reverse(int i) {
  12.         // HD, Figure 7-1
  13.         i = (i & 0x55555555) << 1 | (i >>> 1) & 0x55555555;
  14.         i = (i & 0x33333333) << 2 | (i >>> 2) & 0x33333333;
  15.         i = (i & 0x0f0f0f0f) << 4 | (i >>> 4) & 0x0f0f0f0f;
  16.         i = (i << 24) | ((i & 0xff00) << 8) |
  17.             ((i >>> 8) & 0xff00) | (i >>> 24);
  18.         return i;
  19.     }
复制代码

下面是c语言版本
  1. int reverse(int i) {
  2.         
  3.         i = (i & 0x55555555) << 1 | (i >> 1 & 0x7fffffff) & 0x55555555;
  4.         i = (i & 0x33333333) << 2 | (i >> 2 & 0x3fffffff) & 0x33333333;
  5.         i = (i & 0x0f0f0f0f) << 4 | (i >> 4 & 0xfffffff) & 0x0f0f0f0f;
  6.         i = (i << 24) | ((i & 0xff00) << 8) |
  7.             ((i >> 8 & 0xffffff) & 0xff00) | (i >> 24 & 0xff);
  8.         return i;
  9.     }
复制代码
回复

使用道具 举报

1110

主题

1651

回帖

7万

积分

用户组: 管理员

一只技术宅

UID
1
精华
244
威望
743 点
宅币
24219 个
贡献
46222 次
宅之契约
0 份
在线时间
2296 小时
注册时间
2014-1-26
发表于 2021-6-12 17:49:33 | 显示全部楼层
请使用 uint32_t ,因为你直接使用 int 的话,不同编译器的 << >> 和 & 优先级不同,会导致你的代码在不同编译器上行为不同。

回复 赞! 1 靠! 0

使用道具 举报

1

主题

42

回帖

973

积分

用户组: 大·技术宅

UID
7437
精华
0
威望
112 点
宅币
596 个
贡献
110 次
宅之契约
0 份
在线时间
130 小时
注册时间
2021-9-11
发表于 2023-10-15 09:34:35 | 显示全部楼层
本帖最后由 tlwh163 于 2023-10-16 06:19 编辑

'    'x = (x Shr 1) And &H55555555 Or (x Shl 1) And &HAAAAAAAA    ''奇偶位交换
'    'x = (x Shr 2) And &H33333333 Or (x Shl 2) And &HCCCCCCCC    ''2Bit为1单元,奇偶单元交换
'    'x = (x Shr 4) And &H0F0F0F0F Or (x Shl 4) And &HF0F0F0F0    ''4Bit为1单元,奇偶单元交换
'    'x = (x Shr 8) And &H00FF00FF Or (x Shl 8) And &HFF00FF00    ''8Bit为1单元,奇偶单元交换
'    'x = (x Shr 16) And &H0000FFFF Or (x Shl 16) And &HFFFF0000  ''16Bit为1单元,奇偶单元交换

不知道这个和楼主的代码 原理是不是一样? 哪个更有效率?
使用VFB对2种方法进行编译,GCC2级优化,汇编代码殊途同归...

'    Asm
'        mov   edx, [esp + 4]      ''8B5424 04
'        mov   eax, edx            ''89D0
'        Add   edx, edx            ''01D2
'        Shr   eax, 1              ''D1E8
'        And   edx, &HAAAAAAAA     ''81E2 AAAAAAAA
'        And   eax, &H55555555     ''25 55555555
'        Or    eax, edx            ''09D0
'        mov   edx, eax            ''89C2
'        Shr   edx, 2              ''C1EA 02
'        Shl   eax, 2              ''C1E0 02
'        And   edx, &H33333333     ''81E2 33333333
'        And   eax, &HCCCCCCCC     ''25 CCCCCCCC
'        Or    edx, eax            ''09C2
'        mov   eax, edx            ''89D0
'        Shr   eax, 4              ''C1E8 04
'        Shl   edx, 4              ''C1E2 04
'        And   eax, &H0F0F0F0F     ''25 0F0F0F0F
'        And   edx, &HF0F0F0F0     ''81E2 F0F0F0F0
'        Or    edx, eax            ''09C2
'        mov   eax, edx            ''89D0
'        bswap eax                 ''0FC8
'        ret   4                   ''C2 0400
'    End Asm
回复 赞! 靠!

使用道具 举报

3

主题

5

回帖

11万

积分

用户组: 技术宅的结界VIP成员

UID
8229
精华
2
威望
84 点
宅币
114704 个
贡献
80 次
宅之契约
0 份
在线时间
10 小时
注册时间
2023-2-9
发表于 2023-12-27 18:17:07 | 显示全部楼层
这个经典的算法也被收录在bithacks列表中:https://graphics.stanford.edu/~s ... tml#ReverseParallel

上面也摘录了一些更modern的算法,比如查表法和64位运算法,不知道现代编译器是否会识别原始算法的pattern并且编译成更快的方式。
回复 赞! 靠!

使用道具 举报

QQ|Archiver|小黑屋|技术宅的结界 ( 滇ICP备16008837号 )|网站地图

GMT+8, 2024-4-18 08:42 , Processed in 0.044935 second(s), 29 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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