前端实习二毛钱 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 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题