我正在编写一个简单的程序来将整数(介于0和2147483647之间)转换为32位二进制文件。
不幸的是,输出正在倒退。
例如,我得2 = 10
而不是2 = 01
。
#include<stdio.h>
int main()
{
int finishFlag = 0; //0 = false, 1 = true
while (finishFlag != 1)
{
int a[36],
n = 0,
i = 0, j = 0;
printf("Enter a number between 0 and 2147483647: ");
scanf("%d", &n);
if (n > 0 && n <= 2147483647)
{
printf("%d expressed as a 32-bit binary number is: ", n);
for (i = 0; i < 36; i++)
{
if (n == 1)
{
a[i] = 1;
break;
}
else
{
a[i] = n % 2;
n = n / 2;
}
}
for (j = 0; j <= i; j++)
{
printf("%d", a[j]);
}
printf("\n");
finishFlag = 1;
}
else
printf("\n** Not a valid input, try again ***\n");
}
return 0;
}
另外,我如何显示0的其余部分(包括每8个数字之间的空格)?我需要输出看起来像这样的整数'2'
00000000 00000000 00000000 00000010
答案 0 :(得分:2)
您已经单独打印数字;只需j
从i
开始,将向下计为0.至于打印空间:找出i
需要空格的值,测试对他们而言,只打印一个。
答案 1 :(得分:1)
基本转换算法首先会产生较低的数字,因此您必须反转结果以按通常的阅读顺序显示它们。
一种方法:
void print_in_base (int value, int base)
{
char digit[MAX_DIGITS];
// compute digits
int rank = 0;
while (value != 0)
{
digit[rank++] = '0' + value % base;
value /= base;
}
// display digits in reverse order
while (rank--) printf ("%c", digit[rank]);
}
现在,如果你想每n个字符插入一个空格,你可以这样做:
void print_in_base (int value, int base, int spacing)
{
char digit[MAX_DIGITS];
int rank = 0;
while (value != 0)
{
digit[rank++] = '0' + value % base;
value /= base;
}
while (rank--)
{
printf ("%c", digit[rank]);
if (rank % spacing == 0 && rank != 0) printf (" ");
}
}