看你的stack里存的什么类型了,如果不是指针,可以这么做(这里以int为例)
stack
if (!s.empty())
s.swap(stack
assert(s.empty()); // 此时s就被清空了
没有了,stack是适配器,接口没几个。底层容器的deque或list有一个clear函数,这些都被隐藏了。
stack的清空操作本来就是不断地出栈直到空,你这么写就行了,也不必再想着找什么模板函数去实现了。
有。
#include
using namespace std;
int main(){
stack
......;
st1=empty_st;
return 0;
}
C++ Stack(堆栈) 是一个容器类的改编,为程序员提供了堆栈的全部功能,——也就是说实现了一个先进后出(FILO)的数据结构。
操作 比较和分配堆栈
empty() 堆栈为空则返回真
pop() 移除栈顶元素
push() 在栈顶增加元素
size() 返回栈中元素数目
top() 返回栈顶元素
你可以自己编写一个清空函数empty()