标题:帮我看看这个程序,有问题
只看楼主
张信哲
Rank: 1
等 级:新手上路
帖 子:139
专家分:0
注 册:2008-4-3
 问题点数:0 回复次数:0 
帮我看看这个程序,有问题
#include<stdio.h>
#define Maxsize 30
typedef struct
{
    int s[Maxsize];
    int *top;
    int *base;
}stack;
void initstack(stack *st)
{
    st->top=st->base;
}
int push(stack *st,int x)
{
    if(st->top-st->base>=Maxsize-1)
        return 0;
    else
    {
        *(st->top++)=x;
        return 1;
    }
}
int stackempty(stack st)
{
    if(st.top==st.base)
        return 1;
    else return 0;
}
int pop(stack *st,int x)
{
    if(st->top==st->base)
        return 0;
    else
    {
        x=--(*st->top);
        st->top--;
        return 1;
    }
}
void main()
{
    stack st;
    initstack(&st);
    int n;
    scanf("%d",&n);
    while(n)
    {
        push(&st,n%2);
        n=n/2;
    }
    while(!stackempty(st))
    {
        int e;
        pop(&st,e);
        printf("%d",e);
    }
}
搜索更多相关主题的帖子: stack int base top return 
2008-04-03 11:29



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-206927-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.335669 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved