经过和同学的讨论,这里给出一种更加简单的写法:
#define N 20
#include <iostream>
#include<stdlib.h>
using namespace std;
int main() {
int t, m, n, i, u, p, q;
char s1[N] = { "0123456789ABCDEF" }, s2[N];
s2[0] = '\0';
p = q = u = t = m = n = i = 0;
printf("输入一个十进制数m,和要转换的进制n,格式为:m-n(10<n<17)\n");
scanf("%d-%d", &m, &n);
int a = m, b = n; //输出时候用的,作用不大
if (10 < n && n<17)
{
if (m > n || m == n){ // 初始时候m>=n ,除留余数
for (i = 1; m > n || m == n; i++){
s2[i] = s1[m%n];
m = m / n;
}
s2[i] = s1[m]; //结束循环,此时的m<n,放进数组
}
else
{
i = 1; //初始时候m<n 直接放进数组
s2[i] = s1[m];
}
while (i > 0){
printf("%c", s2[i]);
i--;
}
printf("\0");
}
else
printf("输入错误!\n");
}