大家看一下,顺便注释一下写出的程序

 编写一个将某个范国在-32768 ~32767之间的整数转换为R进制(R=2. 5.8,16)的通用程序。

#include <stdio.h>
#include <stdlib.h>
void trans(int n,int m)
{
    if(n)
    {
        trans(n/m,m);
        if(n%m<10)
            printf("%c",n%m+'0');
        else
            printf("%c",n%m-10+'A');
    }
}
void main()
{
    int n,m;
    printf("输入十进制数N和转化的进制数M:");
    scanf("%d%d",&n,&m);
    printf("十进制数%d转化成%d进制后的结果为:",n,m);
    trans(n,m);
    printf("\n");
}

-32768 ~32767正就是整形数。

#include<stdio.h>


void to_base_n(int n, int b);


int main()
{
int num, base;
printf("输入整数 和 要转换的进制(输入q退出):");
while (scanf("%d %d", &num, &base) == 2)
{
to_base_n(num, base);
printf("输入整数 和 要转换的进制(输入q退出):");
}
printf("bye!\n");
return 0;
}


void to_base_n(int n, int b)
{
char arr[32];
int i,j;
char temp;
if (n < 0)
{
arr[0] = '-';
n = -n;
}
else
{
arr[0] = ' ';
}
for (i = 1,j=0; n > 0; i++)
{
temp = n%b;
if (temp < 10)
{
arr[i] = temp + '0';
}
else
{
arr[i] = temp + '7';
}
n /= b;
j++;
}
printf("%d进制输出:",b);
putchar(arr[0]);
for (i = j; i >=1; i--)
putchar(arr[i]);
printf("\n");
}

 

不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^