C语言编写程序,输入一个十进制整数,将其变换为二进制后储存在一个字符数组中。
时间: 2023-06-02 22:05:30 浏览: 169
好的,这是一个技术问题,可以回答。以下是示例代码:
```c
#include <stdio.h>
#define MAX_SIZE 32 // 假设整数最多包含32位二进制位
int main() {
int num;
printf("请输入一个十进制整数:");
scanf("%d", &num);
char str[MAX_SIZE + 1]; // 储存二进制数的字符串数组
int i = 0;
while (num > 0) {
str[i++] = num % 2 + '0'; // 模2操作得到当前位的二进制位,加上字符'0'(48)后成为字符
num /= 2;
}
str[i] = '\0'; // 字符串结尾
// 将字符串翻转,得到正确的二进制数
int len = i;
for (int i = 0; i < len / 2; i++) {
char temp = str[i];
str[i] = str[len - i - 1];
str[len - i - 1] = temp;
}
printf("对应的二进制数为:%s\n", str);
return 0;
}
```
相关问题
用c语言编写两个程序编写程序,程序一:输入一个十进制整数,将其变换为二进制后储存在一个字符数组中。 程序二:输入任意年月日,计算该天是该年的第几天。
程序一:
```c
#include <stdio.h>
int main() {
int num, i = 0;
char binary[32] = {0};
printf("请输入一个十进制整数:");
scanf("%d", &num);
while(num > 0) {
binary[i++] = num % 2 + '0';
num /= 2;
}
printf("二进制表示为:%s\n", binary);
return 0;
}
```
程序二:
```c
#include <stdio.h>
int main() {
int year, month, day, i, days = 0;
int month_days[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
printf("请输入年月日,格式为yyyy-mm-dd:");
scanf("%d-%d-%d", &year, &month, &day);
for(i = 0; i < month - 1; i++) {
days += month_days[i];
}
if(month > 2 && ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)) {
days += 1;
}
days += day;
printf("%d年%d月%d日是该年的第%d天。\n", year, month, day, days);
return 0;
}
```
C语言编写程序:输入一个十进制整数,将其转换为二进制后反序再转成新的十进制后输出
### 回答1:
我可以提供一个参考的C语言程序: #include <stdio.h>
int main()
{
int n, reverse = 0, remainder;
printf("输入一个十进制整数:");
scanf("%d", &n);
while (n > 0)
{
remainder = n % 2;
reverse = reverse * 10 + remainder;
n = n /2;
}
printf("转换后的十进制数是:%d", reverse);
return 0;
}
### 回答2:
C语言编写程序,实现输入一个十进制整数,将其转换为二进制后反序,再将得到的二进制数转换为新的十进制数并输出。
首先,我们需要使用scanf函数从用户输入获取一个十进制整数,并将其存储在一个整型变量中。
接下来,我们需要使用一个循环来将十进制整数转换为二进制数并进行反序。首先,我们用一个空字符串将二进制数存储起来。然后,我们用除以2的余数不断更新字符串,并将十进制数除以2更新为商,直到十进制数为0为止。这样可以得到反序的二进制数。
接着,我们需要使用一个循环来将反序的二进制数转换为新的十进制数,并将其输出。首先,我们将反序的二进制数作为一个字符串传递给一个整型变量,并设置一个初始值为1的变量result来作为最终的十进制数。然后,我们从字符串的最后一位开始遍历,如果该位上的值为1,则将result加上对应的权值(1、2、4、8、16...);若为0,则保持result不变。最后,将result输出即可得到新的十进制数。
最后,我们需要将程序进行整合,包括上述的输入、转换和输出步骤。注意,我们需要在程序结束前释放之前动态分配的内存空间,而输入的十进制整数和新的十进制数无需释放。
总结起来,这个程序可以实现输入一个十进制整数,将其转换为二进制后反序,再转换为新的十进制数并输出。代码如下:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main() {
int decimal;
printf("请输入一个十进制整数:");
scanf("%d", &decimal);
// 将十进制整数转换为二进制字符串并反序
char* binary = (char*)malloc(sizeof(char) * 32);
int i = 0;
while (decimal != 0) {
binary[i++] = (decimal % 2) + '0';
decimal /= 2;
}
binary[i] = '\0';
strrev(binary); // 反序二进制字符串
// 将二进制字符串转换为新的十进制数并输出
int result = 0;
int power = 1;
for (int j = strlen(binary) - 1; j >= 0; j--) {
if (binary[j] == '1') {
result += power;
}
power *= 2;
}
printf("反序二进制转换为新的十进制数:%d\n", result);
free(binary); // 释放内存空间
return 0;
}
```
使用该程序,用户可以输入一个十进制整数,程序将会将其转换为二进制后反序,并转换为新的十进制数并输出。
### 回答3:
题目要求输入一个十进制整数,将其转换为二进制后反序再转成新的十进制后输出。下面是用C语言编写的程序实现:
```c
#include <stdio.h>
#include <math.h>
int reverse(int n) {
int reversed = 0;
while (n > 0) {
reversed = reversed * 10 + n % 10;
n /= 10;
}
return reversed;
}
int binaryToDecimal(int n) {
int decimal = 0, i = 0, remainder;
while (n != 0) {
remainder = n % 10;
decimal += remainder * pow(2, i);
n /= 10;
i++;
}
return decimal;
}
int main() {
int input, binary, reversed, output;
printf("请输入一个十进制整数:");
scanf("%d", &input);
// 十进制转二进制,然后反序
binary = reverse(input);
// 二进制转十进制
output = binaryToDecimal(binary);
printf("转换后的新十进制数为:%d\n", output);
return 0;
}
```
程序首先定义了两个辅助函数`reverse`和`binaryToDecimal`,分别用于将一个整数反序和将二进制数转换为十进制数。在主函数`main`中,首先获取用户输入的十进制整数,然后将其转换成二进制数并反序。随后,再将反序后的二进制数转换成新的十进制数并输出。最后,程序返回0表示成功结束。
阅读全文