前端实习二毛钱 2017-04-20 12: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 13: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);
        }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 用verilog实现tanh函数和softplus函数
  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启
  • ¥15 51寻迹小车定点寻迹
  • ¥15 谁能帮我看看这拒稿理由啥意思啊阿啊
  • ¥15 关于vue2中methods使用call修改this指向的问题
  • ¥15 idea自动补全键位冲突
  • ¥15 请教一下写代码,代码好难
  • ¥15 iis10中如何阻止别人网站重定向到我的网站
  • ¥15 滑块验证码移动速度不一致问题