十进制数到N进制数的转换

1)问题描述:将从键盘输入的十进制数转换为N(如二进制、八进制、十六进制)进制数据。

2)实验要求: 利用顺序栈实现数制转换问题

3) 实现提示:

转换方法利用辗转相除法;

所转换的N进制数按低位到高位的顺序产生,而通常的输出是从高位到低位的,恰好与计算过程相反,因此转换过程中每得到一位N进制数则进栈保存,转换完毕后依次出栈则正好是转换结果。

4)注意问题:

何时入栈、出栈

​算法结束条件

class Stack:
    def __init__(self):
        self.items = []
    def push(self,item):
        self.items.append(item)
    def pop(self):
        return self.items.pop()

    def peek(self):
        return self.items[len(self.items) -1]

if __name__ == '__main__':
    my_stack_num = Stack()
    """
    a:10进制的数。
    b:需要转换为几进制。
    """
    def test(a,b):
        while (a!=0):
            c=a%b
            a=a//b


            # print('a= %s,b= %d' % (a,c))
            my_stack_num.push(c)
        # print(my_stack_num.items.__len__())
        list =[]
        while (my_stack_num.items.__len__()>0):
            print('my_stack_num.items %s' % (my_stack_num.items))
            print('len %d ' % (my_stack_num.items.__len__()))

            list.append(my_stack_num.pop())
            print('list ',list)
        #将列表变为字符串,但是列表里面存在数字,需要转换一下,先把数字转换为字符串。
        return "".join('%s' % id for id in list)

    x=int(input())
    print(test(x,8))

输入100输出8进制是144

 

#include<stdio.h>
int main() {
    int i = 0, n, a[32];
    printf("请输入一个十进制整数.\n");
    scanf("%d", &n);
    while (n > 0) {
        a[i] = n % 2;
        i = i + 1;
        n = n / 2;
    }
    printf("十进制整数转换为二进制数是:\n");
    for (i--; i >= 0; i--)
        printf("%d", a[i]);
    printf("\n");
    return 0;
}