#include<stdio.h>
#include<math.h>

typedef unsigned int uint;
uint reverse_bit(uint x)
{
	uint i, ret=0;
	for (i = 0; i < 32; i++)
	{
		ret += ((x >> i) & 1)*pow(2, 31 - i); //实际上没有翻转,只是从最低位向最高位扩展求得
	}
	return ret;
}

int main()
{
	unsigned int num, back;
	printf("请输入一个整数:");
	scanf_s("%u", &num);
	back = reverse_bit(num);
	printf("翻转后的值为:%u\n", back);

	system("pause");
	return 0;
}