| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 297 人关注过本帖
标题:将栈中元素逐个出栈
只看楼主 加入收藏
william8070
Rank: 1
等 级:新手上路
帖 子: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
林月儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:湖南
等 级:版主
威 望:138
帖 子:2277
专家分:10647
注 册:2015-3-19
收藏
得分: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
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2015-10-20
收藏
得分:0 
回复 2楼 林月儿
前面那一句 s->next==NULL  算吗?那样可以算是循环执行了吗?如果不是的话,要怎么做啊
2015-11-10 21:30
林月儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:湖南
等 级:版主
威 望:138
帖 子:2277
专家分:10647
注 册:2015-3-19
收藏
得分:0 
以下是引用william8070在2015-11-10 21:30:16的发言:

前面那一句 s->next==NULL  算吗?那样可以算是循环执行了吗?如果不是的话,要怎么做啊


你在说什么?s->next是置空
当然你退栈元素并没有拿来用就是说一次清空和逐个退栈对你来说没什么区别

剑栈风樯各苦辛,别时冰雪到时春
2015-11-10 21:32
快速回复:将栈中元素逐个出栈
数据加载中...
 
   



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

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