用C编写代码将Decimal转换为任何基数我在哪里出错

时间:2018-02-11 22:54:59

标签: c

int convert(int v, int r) //v=value, r=base
{
    int result=0;
    int i=0;
    volatile int remainder = 0;
    while(v > 0){
        remainder = v%r;  //get remainder
        v /= r;  // find the new divisor
        i++;            
    }
    return result;
}

int main(){
    int value = 6;  //convert decimal 6 to binary
    int base = 2;

    volatile int result = 0;
    result = convert(value,base);

    printf(value, base);  

    int base16 = 16;
    int value16 = 50;
    volatile int result16 = 0;

我得到了一个带有while循环和main的模板,作为编写程序以将十进制数转换为任何基数的起点。考虑到代码中已有数学信息,如何编写打印声明?

1 个答案:

答案 0 :(得分:1)

你的所有convert函数都返回0.废弃该函数并重新开始。

你有正确的想法
while(v > 0){
        remainder = v%r;
        v /= r;

但是你需要分别存储每个余数。以vr为模型,可以得出vr之间的其余部分。每个余数为您提供从最低位到最高位的下一个位置值。做这样的事情

int convert (int[], int, int);
int print_base2 (int[], int);

int main ()
{
    int value = 6;
    int base = 2;
    int result[40]; // Enough space for binary if INT_MAX is 2^31 - 1
    int places_written, i;

    places_written = convert (result, value, base);

    if (base == 2)
        print_base2 (result, places_written);
}

int convert (int result[], int value, int base)
{
    int remainder, i = 0;

    while (value > 0) {
        remainder = value % base; // Get next place value
        value /= base; // Move over value by one place
        result[i++] = remainder; // Store the place value
    }

    return i;
}


void print_base2 (int result[], int places_written)
{
    int i;

    // Go backwards and print each value
    for (i = places_written; i > 0; i--) {
        if (result[i - 1] == 1)
            printf ("%c", '1');
        else if (result[i - 1] == 0)
            printf ("%c", '0');
    }
}

注意:如果您只想使用base 2,有更好的方法来获取和打印数字,但您可以根据print_base2对其余功能进行建模。并停止声明所有内容volatile。这是一个坏主意。

修改:您应该在while循环之前检查baseconvert是否为零,因为如果base为零,您的程序将会崩溃。