当前位置: 首页 > news >正文

网站设计岗位的职责与要求wordpress时光轴模板

网站设计岗位的职责与要求,wordpress时光轴模板,海外广告联盟平台推广,做内贸的什么网站效果好介绍完了list类的相关内容后:C初阶:适合新手的手撕list(模拟实现list) 接下来进入新的篇章,stack和queue的介绍以及模拟: 文章目录 1.stack的初步介绍2.stack的使用3.queue的初步介绍4.queue的使用5.容器适…

介绍完了list类的相关内容后:C++初阶:适合新手的手撕list(模拟实现list)
接下来进入新的篇章,stack和queue的介绍以及模拟:


文章目录

  • 1.stack的初步介绍
  • 2.stack的使用
  • 3.queue的初步介绍
  • 4.queue的使用
  • 5.容器适配器
    • 5.1含义
    • 5.2STL标准库中stack和queue的底层结构
  • 6.模拟stack和queue
    • 文件规划和一览
    • 6.1模拟stack(stack.h)
    • 6.2模拟queue(queue.h)


1.stack的初步介绍

image-20240130150337781

  1. stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行元素的插入与提取操作。

  2. stack是作为容器适配器被实现的,容器适配器即是对特定类封装作为其底层的容器,并提供一组特定的成员函数来访问其元素,将特定类作为其底层的,元素特定容器的尾部(即栈顶)被压入和弹出。

  3. stack的底层容器可以是任何标准的容器类模板或者一些其他特定的容器类,这些容器类应该支持以下

操作:

  • empty:判空操作

  • back:获取尾部元素操作

  • push_back:尾部插入元素操作

  • pop_back:尾部删除元素操作

  1. 标准容器vector、deque、list均符合这些需求,默认情况下,如果没有为stack指定特定的底层容器,默认情况下使用deque

Snipaste_2023-12-21_19-43-35


2.stack的使用

1

函数说明
stack()构造空的栈
empty()检测stack是否为空
size()返回stack中元素的个数
top()返回栈顶元素的引用
push()将元素val压入stack中
pop()将stack中尾部的元素弹出
#include<iostream>
#include<stack>
using namespace std;int main()
{stack<int> st;//一个空栈st.push(1);st.push(2);st.push(3);//push进去3个while (!st.empty())//当st不空进循环{cout << st.top() << endl;//输出栈顶元素st.pop();//栈顶出栈}//遍历结束}

image-20240130155021664


3.queue的初步介绍

image-20240130162024817

  1. 队列是一种容器适配器,专门用于在FIFO上下文(先进先出)中操作,其中从容器一端插入元素,另一端提取元素。

  2. 队列作为容器适配器实现,容器适配器即将特定容器类封装作为其底层容器类,queue提供一组特定的成员函数来访问其元素。元素从队尾入队列,从队头出队列。

  3. 底层容器可以是标准容器类模板之一,也可以是其他专门设计的容器类。该底层容器应至少支持以下操作:

  • empty:检测队列是否为空
  • size:返回队列中有效元素的个数
  • front:返回队头元素的引用
  • back:返回队尾元素的引用
  • push_back:在队列尾部入队列
  • pop_front:在队列头部出队列
  1. 标准容器类deque和list满足了这些要求。默认情况下,如果没有为queue实例化指定容器类,则使用标准容器deque。

image-20240130162405130


4.queue的使用

image-20240130162333933

函数说明
queue()构造空的队列
empty()检测队列是否为空,是返回true,否则返回false
size()返回队列中有效元素的个数
front()返回队头元素的引用
back()返回队尾元素的引用
push()在队尾将元素val入队列
pop()将队头元素出队列
#include<iostream>
#include<queue>
using namespace std;int main()
{queue<int> q;//一个空队列q.push(1);q.push(2);q.push(3);//push进去3个while (!q.empty())//当q不空进循环{cout << q.front() << endl;//输出队头元素q.pop();//出队}//遍历结束return 0;
}

在这里插入图片描述


5.容器适配器

5.1含义

容器适配器是一种将现有的容器类型适配为不同接口的容器的工具。C++标准库提供了三种主要的容器适配器:栈(stack)、队列(queue)和优先队列(priority_queue)。这些适配器都是基于现有的序列容器(如vector、deque或list)实现的,但提供了不同的接口和行为。

  1. 栈(stack):栈是一种后进先出(LIFO)的数据结构,它只允许在栈顶进行插入和删除操作。在C++中,栈适配器基于deque或vector实现,提供了push、pop、top等操作。
  2. 队列(queue):队列是一种先进先出(FIFO)的数据结构,它允许在队列的前端进行删除操作,在队列的后端进行插入操作。在C++中,队列适配器也基于deque或list实现,提供了push、pop、front、back等操作。
  3. 优先队列(priority_queue):优先队列是一种特殊的队列,它根据元素的优先级进行排序。在C++中,优先队列适配器基于vector实现,提供了push、pop、top等操作。

今天先来模拟栈和队列。优先队列,下次单独细讲

怎么理解“适配为不同接口的容器”:

容器适配器(上述三种)提供的操作接口与底层容器的操作接口不同。虽然容器适配器底层使用了常见的序列容器(如vector、deque或list)来存储数据,但是它们暴露的操作接口与这些底层容器不同。

举个例子,让我们比较一下栈(stack)适配器和vector容器的接口:

  1. 栈(stack)适配器的接口
  • push:将元素压入栈顶
  • pop:弹出栈顶元素
  • top:访问栈顶元素
  1. vector容器的接口
  • push_back:在vector的末尾插入元素
  • pop_back:删除vector的末尾元素
  • back:访问vector的末尾元素

如你所见,尽管栈适配器的底层容器可能是vector,但它提供了与vector不同的操作接口。栈适配器隐藏了vector的细节,只暴露了栈的相关操作,使得我们可以更方便地使用栈这种数据结构。

5.2STL标准库中stack和queue的底层结构

虽然stack和queue中也可以存放元素,但在STL中并没有将其划分在容器的行列,而是将其称为容器适配器,这是因为stack和队列只是对其他容器的接口进行了包装,STL中stack和queue默认使用deque,比如:

image-20240130164947721


6.模拟stack和queue

文件规划和一览

image-20240130172002973

stack.h:用来实现stack

queue.h:用来实现queue

test.cpp:进行测试

6.1模拟stack(stack.h)

#pragma oncenamespace MyStack
{template<class T, class Container = deque<T>>class stack{public://构造函数、析构函数之类的会去调用传过来的的类的void push(const T& x){_con.push_back(x);}void pop(){_con.pop_front();}const T& top(){return _con.front();}size_t size(){return _con.size();}bool empty(){return _con.empty();}private:Container _con;//封装这个类型};
}

在这里插入图片描述

6.2模拟queue(queue.h)

#pragma oncenamespace MyQueue
{template<class T, class Container = deque<T>>class queue{public://构造函数、析构函数之类的会去调用传过来的的类的void push(const T& x){_con.push_back(x);}void pop(){_con.pop_front();}const T& front(){return _con.front();}const T& back(){return _con.back();}size_t size(){return _con.size();}bool empty(){return _con.empty();}private:Container _con;//封装这个类型};
}

image-20240130175332670


好啦大家,这次就到这里啦!!下次就带来优先级队列priority_queue的介绍和模拟。感谢大家

http://www.yayakq.cn/news/782474/

相关文章:

  • win7 iis配置本地网站威海建设招聘信息网站
  • 模板网站代理公司做网站可以用个人域名
  • 在线代理访问网站的网址网站建设费用兴田德润团队
  • 公司的网站如何做高端定制网站开发设计建站流程
  • 苏州相城区做网站公司门户网站改版建议
  • 帮别人做设计的网站亦庄网站开发
  • 旅行网站模板做网站公司关键词
  • 温州网站 公司广西容县建设网站
  • 著名网站织梦欧亚快递100
  • 湖南做电商网站需要什么条件企业做网站需要多少钱
  • 东莞市外贸网站建设多少钱西海岸城市建设局网站
  • 网站建设拾金手指下拉国内app开发公司
  • 佛山网站设计线上课程制作
  • 校内 实训网站 建设两个网站共用一个空间
  • 全屏响应式网站建设行业门户网站大全
  • 英网站建设如何做盆栽蔬菜网站
  • 电子商务知名网站电信改公网ip可以做网站吗
  • 宣讲家网站李慎明两学一做编程除了做网站还能干什么
  • 网站新功能演示用什么技术做的电子商务网站建设首页流程
  • 一个好的网站建设需要多少钱东莞市领导班子
  • 商城的网站统计如何做北京工商注册公司
  • 有没有哪个网站免费做简历的国外红人营销网站
  • 合肥网站建设代理商如何建立一个网站分享教程
  • .net网站源码下载wordpress 程序员博客主题
  • 中资源 网站域名解析g3云推广是哪家公司的
  • 网站积分系统方案阜阳网站开发
  • jsp和php做网站那个快网站如何在360做提交
  • 闲鱼怎么做钓鱼网站织梦系统网站打开速度慢
  • 湛江市政工程建设公司网站上海网上推广优化
  • 云南制作网站的公司昆明微网站