我正在尝试创建一个将十进制转换为二进制的程序,并在二进制文件之前打印0b。
如果0是输入,我需要程序打印0b0,输入是29时我需要打印0b11101。我似乎可以做一个,但不是另一个,当我修复那个bug时,另一个停止工作
我哪里错了?
#include <stdio.h>
int main()
{
int n,i = 0,j=0,k;
scanf("%d",&n);
int bin[100];
k=n;
//printf("n is %d \n",n);
while(n!=0)
{
//printf("n is %d :\n",n);
bin[i]= n%2;
//printf ("n/2 is %d\n",n%2);
n=(n-n%2)/2;
i++;
//printf("i is %d\n",i);
}
printf("0b");
//if (n='0')
//{
// printf("0");
//}
//else
//{
for (j=i;j>0;j--)
{
//printf("\n j is,%d and there ,is %d\n",j,bin[(j-1)]);
printf("%d",bin[(j-1)]);
}
//}
}
答案 0 :(得分:1)
0不需要被视为特殊情况。只需修复:使用do
循环而不是while ()
。
#include <stdio.h>
int main() {
int n,i = 0,j=0,k;
scanf("%d",&n);
int bin[100];
// k=n; // not needed
// while(n!=0) {
do {
bin[i]= n%2;
// Another simplification
// n=(n-n%2)/2;
n /= 2;
i++;
} while (n);
printf("0b");
for (j=i;j>0;j--) {
printf("%d",bin[(j-1)]);
}
}
处理n<0
所需的其他编码。
答案 1 :(得分:0)
#include <stdio.h>
int main()
{
int n,i = 0,j=0,k;
scanf("%d",&n);
int bin[100];
k=n;
while(n!=0)
{
bin[i]= n%2;
n=(n-n%2)/2;
i++;
}
printf("0b");
if (k==0)
{
printf("0");
}
else
{
for (j=i-1;j>=0;j--)
{
printf("%d",bin[(j-1)]);
}
}
}
答案 2 :(得分:0)
十进制到二进制转换函数的简单且更便携的实现...
#include <limits.h>
void print_binary(unsigned x){
unsigned n=UINT_MAX;
n = ~(n >> 1);
while (n){
if (n & x)
putchar('1');
else
putchar('0');
n = n >> 1;
}
putchar('\n');
}