第七讲 stack

1.  栈(stack)这种数据结构在计算机中是相当出名的。栈中的数据是先进后出的(First In Last Out, FILO)。栈只有一个出口,允许新增元素(只能在栈顶上增加)、移出元素(只能移出栈顶元素)、取得栈顶元素等操作。在STL中,栈是以别的容器作为底部结构,再将接口改变,使之符合栈的特性就可以了。因此实现非常的方便。下面就给出栈的函数列表和VS2008中栈的源代码,在STL中栈一共就5个常用操作函数(top()、push()、pop()、 size()、empty() 

2.  stack中的操作

     stack<int> s;

     s.push(x)      无返回值,将元素x压栈

     s.pop();       退栈,无返回值

     s.top();       取栈顶元素,返回栈顶元素

     s.empty();     判断栈是否为空,如果是空,返回1,否则返回0

     s.size();      返回栈中元素的个数

在栈中没有提供清空操作的函数,但是可以间接地实现清空栈,

   while(!s.empty())

   {    

          s.pop();

   }

 1 #include "stdafx.h"
 2 #include <iostream>
 3 #include <stack>
 4 using namespace std;
 5 
 6 int main()
 7 {
 8     stack<int> iStack;
 9 
10     for(int i = 0; i < 10; ++i)
11     {
12         iStack.push(i);
13     }
14 
15     cout << iStack.size() << endl;
16 
17     while(!iStack.empty())
18     {
19         cout << iStack.top() << " ";
20         iStack.pop();
21     }
22     cout << endl << iStack.size() << endl;
23     return 0;
24 }

posted @ 2014-06-28 21:26  击进的Cocos  阅读(168)  评论(0编辑  收藏  举报