前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >STL——stack容器和queue容器详解

STL——stack容器和queue容器详解

作者头像
P_M_P
发布2024-01-18 19:29:21
900
发布2024-01-18 19:29:21
举报
文章被收录于专栏:C++P_M_P学习笔记C++


💡stack

💡基本概念

栈(stack):一种特殊的线性表,其只允许在固定的一端进行插入和删除操作。在进行数据插入和删除的一端称为栈顶,另一端称为栈底。栈中的元素都遵循后进先出的原则(LIFO,Last In First Out)。 压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶。 出栈:栈的删除操作叫做出栈。出数据也在栈顶。

生活中栈的例子:

常用接口

功能描述:

  • 栈容器常用的对外接口

构造函数:

  • stack<T> stk; //stack采用模板类实现, stack对象的默认构造形式
  • stack(const stack &stk); //拷贝构造函数

赋值操作:

  • stack& operator=(const stack &stk); //重载等号操作符

数据存取:

  • push(elem); //向栈顶添加元素
  • pop(); //从栈顶移除第一个元素
  • top(); //返回栈顶元素

大小操作: empty(); //判断堆栈是否为空 size(); //返回栈的大小

代码语言:javascript
复制
	stack<int>st;
	//入栈
	st.push(10);
	st.push(20);
	st.push(30);
	st.push(40);//栈顶
	
	cout << "size=" << st.size() << endl;

	while (!st.empty())
	{
		cout << st.top() << endl;
		st.pop();
	}

	cout << "size="<<st.size() << endl;

💡queue

💡基本概念

队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出 FIFO(First In First Out) 入队列:进行插入操作的一端称为队尾 出队列:进行删除操作的一端称为队头

💡常用接口

功能描述: 栈容器常用的对外接口 构造函数:

  • queue<T> que; //queue采用模板类实现,queue对象的默认构造形式
  • queue(const queue &que); //拷贝构造函数

赋值操作:

  • queue& operator=(const queue &que); //重载等号操作符

数据存取:

  • push(elem); //往队尾添加元素
  • pop(); //从队头移除第一个元素
  • back(); //返回最后一个元素
  • front(); //返回第一个元素

大小操作:

  • empty(); //判断堆栈是否为空
  • size(); //返回栈的大小
代码语言:javascript
复制
    queue<int>q;
	q.push(10);
	q.push(20);
	q.push(30);
	q.push(40);

	cout << q.front() << endl;//队头元素
	cout << q.back() << endl;//队尾元素

	
	cout <<"size= "<< q.size() << endl;//大小
	//先进先出
	while (!q.empty())
	{
		cout << q.front() << endl;
		q.pop();
	}
	cout <<"size= "<< q.size() << endl;
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-01-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 💡stack
    • 💡基本概念
      • 常用接口
      • 💡queue
        • 💡基本概念
          • 💡常用接口
          相关产品与服务
          容器服务
          腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档