#include <stdio.h>
# define maxize 12
typedef struct {
int tran[maxize];
int *top;
}sqstack;
void initstack(sqstack *s)
{
s->top=s->tran;
}
void push(sqstack *s,int a)
{ int *p;
if(s->top-s->tran>10)
printf("overflow!/n");
else {p=s->top;*p=a;s->top++;};
}
void pop(sqstack *s,int *e)
{ int *p;
if(s->top==s->tran)
{ printf("the stack is empty!/n");
exit(0);
}
p=s->top-1;*e=*p;s->top--;
}
void main()
{ int n,e;
sqstack *s;
s=(sqstack *)malloc(sizeof(sqstack));
initstack(s);
scanf("%d",&n);
while(n)
{ push(s,n%8);
n=n/8;
}
while(s->top-s->tran){
pop(s,&e);
printf("%d",e);
}
}
一个简单的十进制转换为八进制的程序
最新推荐文章于 2024-05-15 13:36:22 发布