对于输入的任意一个非负十进制数,打印输出与其等值的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");
}版权声明:本文为博主原创文章,未经博主允许不得转载。
原文地址:http://blog.csdn.net/zhou554291911/article/details/47026871