数据结构 中数制转换(栈的应用)
发布时间:2021-01-10 11:23:49 所属栏目:创业 来源:网络整理
导读:数据布局 中数制转换(栈的应用) 题目描写: 将一个非负的十进制整数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;
}
感激阅读,但愿能辅佐到各人,感谢各人对本站的支持! (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐
热点阅读

