欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

unsigned int reverse_bit(unsigned int value); 这个函数的返回值value的二进制位模式从左到右翻转后的值。

程序员文章站 2022-07-15 10:08:08
...

如:
在32位机器上25这个值包含下列各位:
00000000000000000000000000011001
翻转后:(2550136832)
10011000000000000000000000000000
程序结果返回:
2550136832

#include<stdio.h>
//unsigned int reverse_bit(unsigned int value)
//这个函数的返回值value的二进制位模式从左到右翻转后的值
unsigned int round(unsigned n) {
	int i;
	unsigned int tmp, sum = 0;
	for (i = 0; i < 32; i++, n /= 2) {
		tmp = n % 2;
		sum = sum * 2 + tmp;
	}
	return sum;
}

int main() {
	printf("%u\n", round(25));
	system("pause");
	return 0;
}