gpt4 book ai didi

c - 32 位字的镜像位

转载 作者:太空狗 更新时间:2023-10-29 17:05:51 25 4
gpt4 key购买 nike

在 C 中你会怎么做? (示例:如果我们必须镜像 8 位,则 10110001 变为 10001101)。某些处理器是否有任何指令可以简化此任务?

最佳答案

它实际上被称为“位反转”,通常在 FFT 加扰中完成。 O(log N) 方式是(最多 32 位):

uint32_t reverse(uint32_t x, int bits)
{
x = ((x & 0x55555555) << 1) | ((x & 0xAAAAAAAA) >> 1); // Swap _<>_
x = ((x & 0x33333333) << 2) | ((x & 0xCCCCCCCC) >> 2); // Swap __<>__
x = ((x & 0x0F0F0F0F) << 4) | ((x & 0xF0F0F0F0) >> 4); // Swap ____<>____
x = ((x & 0x00FF00FF) << 8) | ((x & 0xFF00FF00) >> 8); // Swap ...
x = ((x & 0x0000FFFF) << 16) | ((x & 0xFFFF0000) >> 16); // Swap ...
return x >> (32 - bits);
}

也许这个小小的“可视化”有帮助:
前 3 个赋值的示例,以 uint8_t 示例:

b7 b6 b5 b4  b3 b2 b1 b0
-> <- -> <- -> <- -> <-
----> <---- ----> <----
----------> <----------

好吧,如果我们正在做 ASCII 艺术,这是我的:

7 6 5 4 3 2 1 0
X X X X
6 7 4 5 2 3 0 1
\ X / \ X /
X X X X
/ X \ / X \
4 5 6 7 0 1 2 3
\ \ \ X / / /
\ \ X X / /
\ X X X /
X X X X
/ X X X \
/ / X X \ \
/ / / X \ \ \
0 1 2 3 4 5 6 7

它有点像 FFT 蝴蝶。这就是它与 FFT 一起出现的原因。

关于c - 32 位字的镜像位,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4245936/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com