C++容器简介1—stack
一、简介
stack是一种容器适配器(STL的容器分为顺序容器和关联容器,容器适配器),被设计来用于操作先进后出(FILO)结构的情景,在这种情况下, 元素的插入和删除都只能在容器的尾部进行。
stack通过容器适配器来实现,是一种将特定的容器类作为其最底层的容器的类,它提供了一些特定的成员函数来访问自己的元素,元素只能在这个特定容器的后面,也就是栈的顶部,进行出栈和入栈操作。
最底层的容器可以是任意一种标准的容器模板类,或者是一些有明确目的的容器类,他们应该支持以下操作:
empty(判断是否为空)
size (返回栈的元素个数)
back (返回栈顶元素)
push (入栈)
pop(出栈)
标准的容器类,比如vector,deque,list,满足以上需求。如果没有明确指定需要使用的容器,默认情况下将会使用deque。
二、stack相关函数用法
#include <iostream>
using namespace std;
#include <stack>
void main01() //栈模型
{
stack<int> s;
for (int i = ; i < ; i++)
{
s.push(i + ); //入栈
}
cout << "栈的大小: " << s.size() << endl;
while (!s.empty()) //出栈
{
int tmp = s.top(); //获取栈顶元素
cout << tmp<<" ";
s.pop(); //弹出栈顶元素
}
cout << endl;
}
class Teacher
{
public:
int age;
char name[];
public:
void printT()
{
cout << "age: " << age << endl;
}
};
void main02() //结构体
{
Teacher t1, t2, t3;
t1.age = ;
t2.age = ;
t3.age = ;
stack<Teacher> s;
s.push(t1);
s.push(t2);
s.push(t3);
while (!s.empty())
{
Teacher tmp = s.top();
tmp.printT();
s.pop();
}
}
void main03() //结构体指针
{
Teacher t1, t2, t3;
t1.age = ;
t2.age = ;
t3.age = ;
stack<Teacher*> s;
s.push(&t1);
s.push(&t2);
s.push(&t3);
while (!s.empty())
{
Teacher *p = s.top();
p->printT();
s.pop();
}
}
void main()
{
main01();
main02();
main03();
cout << endl;
cout << "Hello" << endl;
system("pause");
return;
}
1、empty()
返回当前栈是否为空(当它的大小是0的时候),empty()函数并不能清空栈,只是一个返回bool型的const函数。
stack<int>s;
s.push();
s.push();
cout << s.empty() << endl; //输出0
2、size()
返回容器中元素的个数,时间复杂度O(1),返回值类型是size_type,也就是unsigned int。size()函数不能改变栈的大小。
例如上面的代码段应该输出 2
3、top()
返回栈顶元素的引用。
由于栈是一种先进后出的结构,所以最顶部的元素就是最后插入栈的元素。
(C++11中会自动根据元素类型返回reference或者是const_reference,对一个空的栈调用top函数,会异常终止,所以应该使用empty()函数提前检查)
stack<int>s;
s.push();
s.push();
cout << s.top() << endl; //输出2
s.top() += ; //引用可以作为左值
cout << s.top() << endl; //输出5
4.push()和emplace()(c++11)
push()函数和emplace()都是在栈这个容器的顶部插入一个新的元素。
push(),实际上是调用的底层容器的push_back()函数,新元素的值是push函数参数的一个拷贝。
emplace(),实际上是调用的底层容器的emplace_back()函数,新元素的值是在容器内部就地构造的,不需要移动或者拷贝。
stack的emplace也可以用在普通的基本类型上。
struct Node
{
Node(int x)
x(x){}
int x;
};
int main()
{
stack<Node>s1;
s1.emplace();
s1.push(Node());
stack<int>s2;
s2.emplace(); //OK
return ;
}
5、pop()
删除最顶部的元素,使栈的大小减小。
这个被删除的元素,是刚刚插入栈的元素,这个元素和top函数的返回值是一致的。这个函数会调用对象的析构函数(如果有的话),pop()实际上是用过底层容器的pop_back()函数实现的。
(对一个空栈进行pop(),会导致程序异常终止,应该使用empty提前检查 )
stack<int>s;
s.push();
s.push();
s.push();
cout << s.top() << endl; //
s.pop();
cout << s.top() << endl; //
栈没有clear或者erase函数,如果想要清空一个栈,需要循环的调用出栈函数。
stack<int>s;
//s.erase(); //error
//s.clear(); //error
s.push();
s.push();
s.push();
cout << s.size() << endl; //
while(!s.empty())
s.pop();
cout << s.size() << endl; //
6、swap()
交换两个栈的内容(所有元素),这个函数通过非成员函数swap()来交换底层容器,时间复杂度O(1)
// stack::swap
#include <iostream>
using namespace std;
#include <stack>
int main ()
{
std::stack<int> foo,bar;
foo.push (); foo.push(); foo.push();
bar.push (); bar.push();
foo.swap(bar);
std::cout << "size of foo: " << foo.size() << '\n';
std::cout << "size of bar: " << bar.size() << '\n';
return ;
}
7、运算符重载
比较:先大小,后元素
(1) ==
template <class T, class Container>
bool operator== (const stack<T,Container>& lhs, const stack<T,Container>& rhs);
(2) 重载 !=
template <class T, class Container>
bool operator!= (const stack<T,Container>& lhs, const stack<T,Container>& rhs);
(3) 重载 <
template <class T, class Container>
bool operator< (const stack<T,Container>& lhs, const stack<T,Container>& rhs);
(4) 重载 <=
template <class T, class Container>
bool operator<= (const stack<T,Container>& lhs, const stack<T,Container>& rhs);
(5) 重载 >
template <class T, class Container>
bool operator> (const stack<T,Container>& lhs, const stack<T,Container>& rhs);
(6) 重载 >=
template <class T, class Container>
bool operator>= (const stack<T,Container>& lhs, const stack<T,Container>& rhs);例子:
stack<int>l1;
l1.emplace();
l1.emplace();
l1.emplace();
stack<int>l2;
l2.emplace();
l2.emplace();
cout << boolalpha << (l1 > l2) << endl; //T
cout << boolalpha << (l1 == l2) << endl; //F
cout << boolalpha << (l1 != l2) << endl; //T
C++容器简介1—stack的更多相关文章
- java web分享ppt大纲 -- servlet容器简介
今天在公司分享了java web的ppt,把ppt大纲放在这里,希望可以帮助需要的人 servlet容器简介 定义 狭义上的,servlet容器为java Web应用提供运行时环境,负责管理servl ...
- STL容器简介
stl不是面向对象的编程,而是一种不同的编程模式————泛型编程 我们常用到的STL容器有vector.list.deque.map.multimap.set.multiset 顺序性容器:vecto ...
- Docker 容器简介与部署
关于Docker容器技术 参考文献:<docker 从入门到精通> Docker容器简介 Docker的构想是要实现 "Build,Ship and Run Any App,An ...
- Spring(二)核心容器 - 简介 、BeanFactory、ApplicationContext
目录 前言 1.容器简介 2.容器的结构 2.1 BeanFactory 2.2 ApplicationContext 2.2.1 ConfigurableApplicationContext 2.2 ...
- Spring源码-IOC部分-容器简介【1】
实验环境:spring-framework-5.0.2.jdk8.gradle4.3.1 Spring源码-IOC部分-容器简介[1] Spring源码-IOC部分-容器初始化过程[2] Spring ...
- Java集合容器简介
Java集合容器主要有以下几类: 1,内置容器:数组 2,list容器:Vetor,Stack,ArrayList,LinkedList, CopyOnWriteArrayList(1.5),Attr ...
- stl容器学习——queue,stack,list与string
目录 头文件 string 目录部分 1.string的定义及初始化 ① 用一个字符串给另一个字符串赋值 ②用字符串常量对字符串进行赋值 ③ 用n个相同的字符对字符串赋值 2.string的运算符及比 ...
- [转载]Java集合容器简介
Java集合容器主要有以下几类: 1,内置容器:数组 2,list容器:Vetor,Stack,ArrayList,LinkedList, CopyOnWriteArrayList(1.5),Attr ...
- 容器适配器之stack
参见http://www.cplusplus.com/reference/stack/stack/ template<class T, class Container = deque<T& ...
随机推荐
- 【树形DP】骑士
骑士 题目描述 \(Z\)国的骑士团是一个很有势力的组织,帮会中汇聚了来自各地的精英.他们劫富济贫,惩恶扬善,受到社会各界的赞扬. 最近发生了一件可怕的事情,邪恶的\(Y\)国发动了一场针对Z国的侵略 ...
- MongoDB 数据库备份还原
数据库备份 在 Mongodb 中我们使用 mongodump 命令来备份 MongoDB 数据.该命令可以导出所有数据 到指定目录中. mongodump 命令可以通过参数指定导出的数据量级转存的服 ...
- fluent meshing建立周期性网格
原视频下载地址:https://pan.baidu.com/s/1pKUXKgz 密码: 6pwh
- 【Java 8】巧用Optional之优雅规避NPE问题
避之不及的 NullPointerException NPE : NullPointerException 空指针异常是最常见的Java异常之一,抛出NPE错误不是用户操作的错误,而是开发人员的错误, ...
- Goroutine调度器
前言 并发(并行)一致都是编程语言的核心主题,不同于其他语言,例如C/C++语言用户序自行借助pthread创建线程,Golang天然就给出了并发解决方案:goroutine. Goroutine 写 ...
- Laravel模型事件的实现原理详解
模型事件在 Laravel 的世界中,你对 Eloquent 大多数操作都会或多或少的触发一些模型事件,下面这篇文章主要给大家介绍了关于Laravel模型事件的实现原理,文中通过示例代码介绍的非常详细 ...
- uniapp - 如何申请阿里云存储
长话短说,简略表述 1. 登录阿里云,选择 oos对象云存储 https://oss.console.aliyun.com/overview 2. 新建“Bucket”,名称是唯一的(建议用公司或者个 ...
- Multi-Agent Reinforcement Learning Based Frame Sampling for Effective Untrimmed Video Recognition
Multi-Agent Reinforcement Learning Based Frame Sampling for Effective Untrimmed Video Recognition IC ...
- SQLServer replace函数
declare @name char(1000) --注意:char(10)为10位,要是位数小了会让数据出错 set @name='ssssfcfgghdghdfcccs' select repla ...
- asp.net core mvc 读取appsettings.config中文乱码问题
asp.net core mvc 读取appsettings.config中文乱码问题的解决方法如下: 用记事本打开appsettings.config,另存为的时候,编码设置为 “UTF-8”,