对于输入的任意一个非负十进制数,打印输出与其等值的N进制数
#define N 8
void conversion(){
SqStack s;
unsigned n;//非负整数
SElemType e;
InitStack(s);
printf("将十进制整数转化为%d进制数,请输入:n(>=0) = ", N);
scanf("%u", &n);
while (n)
{
Push(s, n%N);//入栈n除以N的余数(N进制的低位)
n = n / N;
}
while (!StackEmpty(s)){
Pop(s, e);//弹出栈顶元素并赋给e
printf("%d", e);
}
printf("\n");
}
N只能是小于10的数字,从十进制转十六进制需要将10~15转换为A~F输出
void conversion(){
SqStack s;
unsigned n;//非负整数
SElemType e;
InitStack(s);
printf("将十进制整数转化为十六进制数,请输入:n(>=0) = ");
scanf("%u", &n);
while (n)
{
Push(s, n%16);//入栈n除以16的余数(16进制的低位)
n = n / 16;
}
while (!StackEmpty(s)){
Pop(s, e);//弹出栈顶元素并赋给e
if (e <= 9)
printf("%d", e);//小于等于9的余数直接输出
else
printf("%d", e + 55);//大于9的余数,输出相应字符
}
printf("\n");
}