搜索
编程论坛
→
开发语言
→
『 C语言论坛 』
→ 将栈中元素逐个出栈
标题:
将栈中元素逐个出栈
只看楼主
william8070
等 级:
新手上路
帖 子:17
专家分:0
注 册:2015-10-20
结帖率:
0
楼主
已结贴
√
问题点数:5 回复次数:3
将栈中元素逐个出栈
bool pop(listack *&s,elemtype &e)
{ listack *p;
if (s->next=NULL)
return false;
p=s->next;
e=p->data;
s->next=p->next;
free(p);
return true;
}
这样的一段代码,出栈的仅仅是栈顶元素吗?如果是的话,怎么循环执行这段程序将栈中元素都出栈啊!
2015-11-10 21:14
林月儿
来 自:湖南
等 级:
版主
威 望:
138
帖 子:2276
专家分:10647
注 册:2015-3-19
第
2
楼
得分:5
bool pop(listack *&s,elemtype &e)
{ listack *p;
if (s->next=NULL)
return false;
p=s->next;
e=p->data;
s->next=p->next;
free(p);
return true;
}
如果是头插法建栈可以说是退栈操作,但是pop的返回值类型真的是够了
想要循环执行加个判断栈空的条件限制不就好了
剑栈风樯各苦辛,别时冰雪到时春
2015-11-10 21:21
william8070
等 级:
新手上路
帖 子:17
专家分:0
注 册:2015-10-20
第
3
楼
得分:0
回复 2楼 林月儿
前面那一句 s->next==NULL 算吗?那样可以算是循环执行了吗?如果不是的话,要怎么做啊
2015-11-10 21:30
林月儿
来 自:湖南
等 级:
版主
威 望:
138
帖 子:2276
专家分:10647
注 册:2015-3-19
第
4
楼
得分:0
以下是引用
william8070
在2015-11-10 21:30:16的发言:
前面那一句 s->next==NULL 算吗?那样可以算是循环执行了吗?如果不是的话,要怎么做啊
你在说什么?s->next是置空
当然你退栈元素并没有拿来用就是说一次清空和逐个退栈对你来说没什么区别
剑栈风樯各苦辛,别时冰雪到时春
2015-11-10 21:32
4
1/1页
1
参与讨论请移步原网站贴子:
https://bbs.bccn.net/thread-459077-1-1.html
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.228170 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved