输入一个十进制正整数,将它对应的二进制数的各位反序,形成新的十进制数输出 C语言
时间: 2024-03-09 22:49:05 浏览: 183
可以使用位运算和循环来解决这个问题,具体实现如下:
```c
#include <stdio.h>
int main() {
int n, i, reversed = 0;
printf("请输入一个十进制正整数:");
scanf("%d", &n);
for (i = 0; n > 0; i++) {
reversed = (reversed << 1) | (n & 1); // 将n的最低位插入到reversed的最高位
n >>= 1; // 将n向右移动一位
}
printf("反序后的二进制数为:%d\n", reversed);
return 0;
}
```
输入一个十进制正整数,例如输入10,输出结果为:
```
请输入一个十进制正整数:10
反序后的二进制数为:5
```
解释:10的二进制数为1010,反序后为0101,对应的十进制数为5。
注意:上述代码中使用了位运算符号 `<<` 和 `|`,需要了解位运算的相关知识。
阅读全文