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

2025-01-31 01:20:08
推荐回答(5个)
回答1:

看你的stack里存的什么类型了,如果不是指针,可以这么做(这里以int为例)
stack s;
if (!s.empty())
s.swap(stack());
assert(s.empty()); // 此时s就被清空了

回答2:

没有了,stack是适配器,接口没几个。底层容器的deque或list有一个clear函数,这些都被隐藏了。

回答3:

stack的清空操作本来就是不断地出栈直到空,你这么写就行了,也不必再想着找什么模板函数去实现了。

回答4:

有。
#include
using namespace std;
int main(){
stackst1,empty_st;

......;

st1=empty_st;

return 0;

}

回答5:

C++ Stack(堆栈) 是一个容器类的改编,为程序员提供了堆栈的全部功能,——也就是说实现了一个先进后出(FILO)的数据结构。

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

你可以自己编写一个清空函数empty()