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的模板,作为编写程序以将十进制数转换为任何基数的起点。考虑到代码中已有数学信息,如何编写打印声明?
答案 0 :(得分:1)
你的所有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');
}
}
注意:如果您只想使用base 2,有更好的方法来获取和打印数字,但您可以根据print_base2
对其余功能进行建模。并停止声明所有内容volatile
。这是一个坏主意。
修改:您应该在while循环之前检查base
中convert
是否为零,因为如果base
为零,您的程序将会崩溃。