将整数转换为32位二进制 - 输出是向后的

时间:2015-02-23 20:46:52

标签: c binary integer converter

我正在编写一个简单的程序来将整数(介于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

2 个答案:

答案 0 :(得分:2)

您已经单独打印数字;只需ji开始,将向下计为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 (" ");
    } 
}