数据结构 中数制转换(栈的应用)
发布时间:2021-01-12 03:36 所属栏目:[王中王论坛] 来源:网络整理
导读:数据结构 中数制转换(栈的应用) 问题描述: 将一个非负的十进制整数N转换为另一个等价的基为B的B进制数的问题。 解答:按除2取余法,得到的余数依次是1、0、1、1,则十进制数转化为二进制数为1101。 分析:由于最先得到的余数是转化结果的最低位,最后得到的
数据结构 中数制转换(栈的应用) 问题描述: 将一个非负的十进制整数N转换为另一个等价的基为B的B进制数的问题。 解答:按除2取余法,得到的余数依次是1、0、1、1,则十进制数转化为二进制数为1101。 分析:由于最先得到的余数是转化结果的最低位,最后得到的余数是转化结果的最高位,因此很容易用栈来解决。 代码如下: #include<stdio.h> #include<malloc.h> #include<stdlib.h> typedef struct Node { int data; struct Node * pNext; }NODE,*PNODE; typedef struct Stack { PNODE pTop; PNODE pBottom; }STACK,*PSTACK; bool empty(PSTACK ps) { if(ps->pTop == ps->pBottom) return true; else return false; } void initstack(PSTACK ps) { ps->pTop=(PNODE)malloc(sizeof(NODE)); if (NULL == ps->pTop) { printf("初始化失败!\n"); exit(-1); } else { ps->pBottom=ps->pTop; ps->pTop->pNext=NULL; } return ; } void push(PSTACK ps,int val) { PNODE pNew=(PNODE)malloc(sizeof(NODE)); pNew->data=val; pNew->pNext=ps->pTop; ps->pTop=pNew; return; } void pop(PSTACK ps) { int x; if(empty(ps)) { //printf("出栈失败!"); return ; } else { PNODE p=ps->pTop; x=p->data; ps->pTop=p->pNext; free(p); p=NULL; printf("%d",x); return ; } } int main() { int i,N,B; STACK S; scanf("%d",&N); scanf("%d",&B); initstack(&S); while(N) { push(&S,N%B); N=N/B; } while(S.pBottom!=NULL) { pop(&S); } system("pause"); return 0; } 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! 【免责声明】本站内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。 |
相关内容
网友评论
推荐文章
-
链表概述 链表是一种常见的重要的数据结构。它是动态...[详细]
-
详谈全排列next_permutation() 函数的用法(推荐)
这是一个c++函数,包含在头文件algorithm里面,下面是...[详细]
-
利用boost来获取当前时间又方便快捷,还不用考虑跨平...[详细]
-
对称矩阵及稀疏矩阵的压缩存储 1.稀疏矩阵 对于那些零...[详细]
-
Windows下调整Tomcat启动参数 Tomcat默认可以使用的内...[详细]
-
打开注册表: win+R ,输入 regedit 点击确定 你会看到...[详细]
-
C语言中的操作符优先级的详细介绍 C语言中操作符的优...[详细]
-
1、在UI设计界面放置两个输入lineEdit、一个输出TextB...[详细]
-
本文主要给大家介绍了关于如何获取C++类成员虚函数地...[详细]
-
本篇章节讲解C++中的聚合类。供大家参考研究具体如下...[详细]
热点阅读