|
发表于 2018-4-23 16:32:02
From FishC Mobile
|
显示全部楼层
|阅读模式
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 幽梦三影 于 2018-4-23 16:39 编辑
int Push(SqStack &S,SElemType e)
{
if(S.top-S.base>=S.stacksize)
{
S.base=(SElemType *)malloc(S.stacksize+STACKINCREMENT*sizeof(SElemType));
if(!S.base)
{
printf("存储分配失败!\n");
exit(ERROR);
}
S.top=S.base+S.stacksize;
S.stacksize=S.stacksize+STACKINCREMENT;
}
*S.top=e;
S.top++;
// printf("入栈成功!\n");
return OK;
}
你的代码真心看不懂。
S.base 不是 S->base
malloc 为什么不是 realloc
realloc 功能说明:
先判断当前的指针是否有足够的连续空间,如果有,扩大mem_address指向的地址,并且将mem_address返回,如果空间不够,先按照newsize指定的大小分配空间,将原有数据从头到尾拷贝到新分配的内存区域,而后释放原来mem_address所指内存区域(注意:原来指针是自动释放,不需要使用free),同时返回新分配的内存区域的首地址。即重新分配存储器块的地址。
- #define STACKINCREMENT 10
- Push(sqStack *s, ElemType e)
- {
- // 如果栈满, 追加空间
- if(s->top - s->base >= s->stackSize)
- {
- s->base = (ElemType *)realloc(s->base, (s->stackSize + STACKINCREMENT) * sizeof(ElemType));
- if(!s->base)
- exit(0);
- s->top = s->base + s->stackSize; // 设置栈项
- s->stackSize = s->stackSize + STACKINCREMENT; // 设置栈的最大容量
- }
- *(s->top) = e;
- s->top++;
- }
复制代码
|
|