| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 957 人关注过本帖
标题:帮我看看这个程序,有问题
只看楼主 加入收藏
张信哲
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
快速回复:帮我看看这个程序,有问题
数据加载中...
 
   



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

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