繁体   English   中英

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

[英]Write code in C to convert Decimal to any base Where am I going wrong

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 的模板,作为编写程序将十进制数转换为任何基数的起点。 鉴于代码中已经包含数学信息,我该如何编写打印语句?

您的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');
    }
}

注意:如果您只想使用基数 2,有更好的方法来获取和打印数字,但您可以基于print_base2对其余函数进行print_base2 并停止声明一切都是volatile 这是个坏主意。

编辑:您应该检查base是零convert while循环之前,因为如果你的程序会崩溃base是零。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM