C++STL中的stack如何清空?

我写的是while(s.empty()==false)s.pop();有没有简单的模板函数可以实现呢?... 我写的是
while(s.empty()==false)s.pop();
有没有简单的模板函数可以实现呢?
展开
 我来答
被主遗弃的人
推荐于2017-12-08 · TA获得超过1079个赞
知道小有建树答主
回答量:977
采纳率:50%
帮助的人:386万
展开全部
看你的stack里存的什么类型了,如果不是指针,可以这么做(这里以int为例)
stack<int> s;
if (!s.empty())
s.swap(stack<int>());
assert(s.empty()); // 此时s就被清空了
捣蒜大师Edison
2017-12-08 · TA获得超过2963个赞
知道大有可为答主
回答量:3825
采纳率:77%
帮助的人:1332万
展开全部
没有了,stack是适配器,接口没几个。底层容器的deque或list有一个clear函数,这些都被隐藏了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cjjohn3
2017-12-08 · TA获得超过6644个赞
知道大有可为答主
回答量:3622
采纳率:69%
帮助的人:996万
展开全部
stack的清空操作本来就是不断地出栈直到空,你这么写就行了,也不必再想着找什么模板函数去实现了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
emmalu929
2023-01-01
知道答主
回答量:1
采纳率:0%
帮助的人:284
展开全部
有。
#include <bits/stdc++.h>
using namespace std;
int main(){
stack<int>st1,empty_st;

......;

st1=empty_st;

return 0;

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
hi_xjy
2010-10-27 · TA获得超过2468个赞
知道大有可为答主
回答量:987
采纳率:0%
帮助的人:1537万
展开全部
C++ Stack(堆栈) 是一个容器类的改编,为程序员提供了堆栈的全部功能,——也就是说实现了一个先进后出(FILO)的数据结构。

操作 比较和分配堆栈
empty() 堆栈为空则返回真
pop() 移除栈顶元素
push() 在栈顶增加元素
size() 返回栈中元素数目
top() 返回栈顶元素

你可以自己编写一个清空函数empty()
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式