题目描述
将十进制整数n转换成二进制,并保存在字符数组中,最后输出。要求定义并调用convert()函数, 将十进制整数n对应的二进制数存入字符数组str中。
void convert(int n, char str[]);
输入
输入一个非负整数n,n<2^31。
输出
输出一个01字符串,即n对应的二进制数,不含前导0。输出占一行。
样例输入
13
样例输出
1101
注意
二进制中不含前导0:比如18,在一个32位的计算机内部被表达为00000000000000000000000000011000。可以看到,从左边数过来,在第一个1之前,有27个0。我们把这些0称作前导的零。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/**进制转换
将十进制整数n转换成二进制,并保存在字符数组中,最后输出。
要求定义并调用convert()函数, 将十进制整数n对应的二进制数存入字符数组str中。
void convert(int n, char str[]);
输入
输入一个非负整数n,n<2^31。
输出
输出一个01字符串,即n对应的二进制数,不含前导0。输出占一行。*/
void convert(int n, char str[]);
int main()
{
int n;
scanf("%d", &n);
char str[10000]; //注意数组是否越界,否则会导致运行错误
convert(n ,str);
return 0;
}
void convert(int n, char str[]){
int i=0, j;
if(n == 0){
printf("0");
}
while(n != 0){
str[i++] = n % 2 + '0'; //变为字符类型
n = n / 2;
}
int len = i;
for(j = len-1; j >= 0; j--){
printf("%c",str[j]);
}
}