| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 416 人关注过本帖
标题:[求助]在学习栈时出现问题,请教
取消只看楼主 加入收藏
applegrape02
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2007-3-21
收藏
 问题点数:0 回复次数:0 
[求助]在学习栈时出现问题,请教

出错处以标出,不知道该如何改

#include<stdio.h>
#include<malloc.h>
#define stack_init_size 10;
#define stackincrement 10;
typedef struct stack
{
int *base;
int *top;
int stacksize;
};

struct stack initstack()
{
struct stack s;
s.base=(int *) malloc (stack_init_size * sizeof(int));//出错
if(s.base==NULL) printf("error");
s.top=s.base;
s.stacksize=stack_init_size;
return s;
}

void push(struct stack s,int a)
{
if(s.top-s.base>=s.stacksize)
{
s.base=(int*)realloc(s.base, (stack_init_size+stackincrement)*sizeof(int));//出错
if(!s.base) printf("error!");
s.top=s.base+s.stacksize;
s.stacksize+=stackincrement;
}
*s.top++=a;
}

int gettop(struct stack s)
{
int e;
if(s.top==s.base) return 0;
e=*s.top++;
return e;
}

int stackempty(struct stack s)
{
if(s.base!=s.top) return 0;
else return 1;
}

int main()
{
int n,e;
struct stack s;
s=initstack();
printf("input an int number:");
scanf("%d",n);
while(n)
{
push(s,n%8);
n=n/8;
}
while(!stackempty(s))
{
e=gettop(s);
printf("%d",e);
s.top--;
}

return 0;
}

搜索更多相关主题的帖子: include return 如何 
2007-04-28 19:15
快速回复:[求助]在学习栈时出现问题,请教
数据加载中...
 
   



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

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