| 编程中国 | 业界新闻 | 技术文章 | 视频教程 | 下载频道 | 程序源码 | 个人空间 | 编程论坛
全能ASP/PHP/ASP.NET主机,支持月付专业 MSSQL 数据库空间,支持月付专业 MySQL 数据库空间,支持月付学习型 ASP/PHP/ASP.NET 主机 30元/年
高端软件开发 = 年薪十万不是梦赛孚耐:软件保护加密专家身份认证令牌USB KEY 
共有 267 人关注过本帖
标题:程序中一个奇怪的问题
收藏  订阅  推荐  打印 
mingreign
Rank: 2
等级:注册会员
帖子:66
积分:762
注册:2007-9-15
程序中一个奇怪的问题

#include <stdio.h>
#include <stdlib.h>
#define stackinitsize  100
#define stackincrement 10
#define overflow  0
#define ok  1
#define error 0
typedef struct{
    int  *base;
    int  *top;
    int  stacksize;
}*sqstack;
int initstack(sqstack &s)      //构造一个空栈
{
    s->base=(int*)malloc(stackinitsize*sizeof(int));
    if(!s->base) exit(overflow);
    s->top=s->base;
    s->stacksize=stackinitsize;
    return 0;
}
int push(sqstack &s,int e)      //插入元素e为新的栈顶元素
{
    if(s->top-s->base>=s->stacksize)
    {
        s->base=(int*)realloc(s->base,(s->stacksize+stackincrement)*sizeof(int));
        if(!s->base)exit(overflow);
        s->top=s->base+s->stacksize;
        s->stacksize+=stackincrement;
    }
    *s->top++ =e;
    return ok;
}
int pop(sqstack &s,int  &e)    //删除栈顶元素
{
    if(s->top==s->base)
        return error;
    e=*--s->top;
    return ok;
}
int gettop(sqstack s, int &e)   //返回栈顶元素
{
    if(s->top==s->base)  
        return error;
    e=*(s->top-1);
    return ok;
}
void main()
{
  int e;
  int initstack(sqstack &s);
  printf("请输入需要压入栈的数:");
  scanf("%d",e);
  int push(sqstack  s,   e);
  int gettop(sqstack s,   e);
}
搜索更多相关主题的帖子: int  base  define  overflow  
2008-3-24 16:02
mingreign
Rank: 2
等级:注册会员
帖子:66
积分:762
注册:2007-9-15
好呀

希望各位同仁帮个忙,谢谢哥们了。
2008-3-24 16:05
hyq1122
Rank: 1
等级:新手上路
帖子:23
积分:338
注册:2008-3-24
到底什么问题?

你贴个代码就叫人回答问题拉?
2008-3-25 09:24
关于我们 | 广告合作 | 编程中国 | 清除Cookies | Archiver | WAP | TOP

编程中国 版权所有,并保留所有权利。鲁ICP备08000592号
Powered by Discuz, Processed in 0.053448 second(s), 9 queries.
Copyright©2004-2008, BCCN.NET, All Rights Reserved