前端实习二毛钱 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#的问题,如何解决?(相关搜索:信噪比,系统容量)
  • ¥500 52810做蓝牙接受端
  • ¥15 基于PLC的三轴机械手程序
  • ¥15 多址通信方式的抗噪声性能和系统容量对比
  • ¥15 winform的chart曲线生成时有凸起
  • ¥15 msix packaging tool打包问题
  • ¥15 finalshell节点的搭建代码和那个端口代码教程
  • ¥15 Centos / PETSc / PETGEM
  • ¥15 centos7.9 IPv6端口telnet和端口监控问题
  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作