C++ 栈库 - stack() 函数



描述

C++ 复制构造函数 std::stack::stack() 使用另一个栈中存在的每个元素的副本构造一个栈。

声明

以下是来自 std::stack 头文件的 std::stack::stack() 构造函数的声明。

C++11

template <class Alloc>
stack (const stack& x, const Alloc& alloc);

参数

  • x − 另一个相同类型的栈对象。

  • alloc − 分配器对象。

返回值

构造函数永不返回值。

异常

此成员函数永不抛出异常。

时间复杂度

线性,即 O(n)

示例

以下示例演示了 std::stack::stack() 构造函数的使用。

#include <iostream>
#include <stack>

using namespace std;

int main(void) {   
   stack<int> s1;

   for (int i = 0; i < 5; ++i)
      s1.push(i + 1);

   stack<int> s2(s1);

   cout << "Contents of stack s2" << endl;
   while (!s2.empty()) {
      cout << s2.top() << endl;
      s2.pop();
   }

   return 0;
}

让我们编译并运行以上程序,这将产生以下结果:

Contents of stack s2
5
4
3
2
1
stack.htm
广告