前端实习二毛钱 2017-04-20 04:45 采纳率: 100%
浏览 905
已采纳

这个代码问题出在哪里,求大神帮忙看一下

运用栈实现十进制数转八进制。
#include"stdio.h"
#define max 10
typedef struct stack
{
int top;
int a[max];
}sqstack;

void initstack(sqstack &s)
{
s.top=0;
}

int full(sqstack s)
{
if(s.top==max) return 1;
else return 0;
}
int empty(sqstack s)
{
if(s.top==0) return 0;
else return 1;
}
void push(sqstack &s,int e)
{
if(full(s)==1) printf("full/n");
else
{
s.a[s.top]=e;
s.top++;
}
}
void pop(sqstack &s,int &e)
{
if(empty(s)==1) printf("empty");
else{
s.top--;
e=s.a[s.top];
}
}
void convesion(int n)
{
sqstack ss;
int stack(ss);
do{
push(ss,n%8);
n=n/8;
}while(n>0)
while(empty(ss)==0)
{
int x;
pop(ss,x);
printf("%d",x);
}
}
void main()
{
int n;
scanf("%d",&n);
conversion(n);

}

展开全部

  • 写回答

1条回答 默认 最新

  • 内核之道 PostgreSQL领域优质创作者 2017-04-20 05:29
    关注

    /****已经调试好,凡是有取地址&符号的地方都把&去掉********/

     #include"stdio.h"
    #define max 10
    typedef struct stack
        {
        int top;
        int a[max];
        }sqstack;
    
    void initstack(sqstack s)
        {
        s.top=0;
        }
    
    int full(sqstack s)
        {
        if(s.top==max) return 1;
        else return 0;
        }
    
    int empty(sqstack s)
        {
        if(s.top==0) return 0;
        else return 1;
        }
    
    void push(sqstack s,int e)
        {
        if(full(s)==1) printf("full/n");
        else 
            {
            s.a[s.top]=e;
            s.top++;
            }
        }
    
    /****不要加取地址&符号,凡是有取地址&符号的地方都把&去掉****/
    void pop(sqstack s,int e)
        {
        if(empty(s)==1) printf("empty");
        else{
            s.top--;
            e=s.a[s.top];
            }
        }
    
    void convesion(int n)
        {
    
        sqstack ss;
        int stack(ss);
        do{
            push(ss,n%8);
            n=n/8;
    
            /**** while(n>0)后面确实分号 ; ****/
            }while(n>0);
                while(empty(ss)==0)
                    {
                    int x;
                    pop(ss,x);
                    printf("%d",x);
                    }
        }
    
    
    void main()
        {
        int n;
        scanf("%d",&n);
    #if 0
         /****conversion(n);函数名写错了,应为convesion ****/
        //conversion(n);
    #endif
        convesion(n);
        }
    

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部