![](/img/trans.png)
[英]This is C code for evaluation of a postfix expression. I have added comments to see where I am going wrong
[英]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;
但是您需要单独存储每个剩余部分。 以v
模r
为您提供v
和r
之间的余数。 每个余数为您提供从最低顺序到最高顺序的下一个位置值。 做这样的事情
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.