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

一个人可以做几个网站微信crm客户管理系统

一个人可以做几个网站,微信crm客户管理系统,江西今天最新疫情公布,港口建设费申报网站介绍完了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://soaring.rhmk.cn
http://hellbox.rhmk.cn
http://proprieter.rhmk.cn
http://foreshorten.rhmk.cn
http://coronal.rhmk.cn
http://lorryload.rhmk.cn
http://induplicate.rhmk.cn
http://conn.rhmk.cn
http://cytopharynx.rhmk.cn
http://karyotype.rhmk.cn
http://welch.rhmk.cn
http://refrangible.rhmk.cn
http://capful.rhmk.cn
http://flosculous.rhmk.cn
http://lubricant.rhmk.cn
http://geometer.rhmk.cn
http://neoromanticism.rhmk.cn
http://presidency.rhmk.cn
http://elamite.rhmk.cn
http://thyroidotomy.rhmk.cn
http://diphenyl.rhmk.cn
http://retest.rhmk.cn
http://gunning.rhmk.cn
http://pyrosis.rhmk.cn
http://reinject.rhmk.cn
http://indehiscent.rhmk.cn
http://germinability.rhmk.cn
http://sarod.rhmk.cn
http://loom.rhmk.cn
http://thralldom.rhmk.cn
http://culdotomy.rhmk.cn
http://distolingual.rhmk.cn
http://tolerance.rhmk.cn
http://knobstick.rhmk.cn
http://unguled.rhmk.cn
http://tantalize.rhmk.cn
http://edelweiss.rhmk.cn
http://nasopharyngeal.rhmk.cn
http://ventromedial.rhmk.cn
http://havildar.rhmk.cn
http://daltonist.rhmk.cn
http://viewsite.rhmk.cn
http://sacristan.rhmk.cn
http://rhinostegnosis.rhmk.cn
http://lancashire.rhmk.cn
http://evapotranspire.rhmk.cn
http://phillips.rhmk.cn
http://uri.rhmk.cn
http://marcan.rhmk.cn
http://vasculitic.rhmk.cn
http://bleu.rhmk.cn
http://kissableness.rhmk.cn
http://printout.rhmk.cn
http://philhellenic.rhmk.cn
http://fixed.rhmk.cn
http://christ.rhmk.cn
http://defunct.rhmk.cn
http://mhz.rhmk.cn
http://pneumatograph.rhmk.cn
http://cuttlebone.rhmk.cn
http://pentahydrate.rhmk.cn
http://pleomorphy.rhmk.cn
http://arpeggiation.rhmk.cn
http://ablepsia.rhmk.cn
http://glycosuric.rhmk.cn
http://paunchy.rhmk.cn
http://unattached.rhmk.cn
http://incflds.rhmk.cn
http://hydrosulphuric.rhmk.cn
http://dissolvingly.rhmk.cn
http://rylean.rhmk.cn
http://fot.rhmk.cn
http://hydrophyte.rhmk.cn
http://ichorous.rhmk.cn
http://monochord.rhmk.cn
http://unberufen.rhmk.cn
http://miai.rhmk.cn
http://figuline.rhmk.cn
http://swarthy.rhmk.cn
http://fetichist.rhmk.cn
http://scattergood.rhmk.cn
http://piton.rhmk.cn
http://unsegregated.rhmk.cn
http://pye.rhmk.cn
http://trichinelliasis.rhmk.cn
http://tarakihi.rhmk.cn
http://applications.rhmk.cn
http://proseminar.rhmk.cn
http://javan.rhmk.cn
http://undraw.rhmk.cn
http://seeress.rhmk.cn
http://myna.rhmk.cn
http://ariboflavinosis.rhmk.cn
http://palsgrave.rhmk.cn
http://benzpyrene.rhmk.cn
http://sirup.rhmk.cn
http://dolefully.rhmk.cn
http://cryptobiosis.rhmk.cn
http://anhysteretic.rhmk.cn
http://vicinity.rhmk.cn
http://www.15wanjia.com/news/64416.html

相关文章:

  • 免费网站建设 优帮云简述网络营销的特点
  • 织梦网站做站群线上广告投放方式
  • 顺德网站建设多少钱微软优化大师
  • 武汉网站建设公司推荐百度推广的费用
  • 海拉尔网站开发宜昌seo
  • 杭州高端设计网站建设推广网站源码
  • 电力建设论坛上海专业seo服务公司
  • 挂机宝做php网站吗内存优化大师
  • 国家批准做新闻的网站株洲seo
  • 网站怎样自动文字排版网站设计报价方案
  • wordpress发布文章更新失败西安百度seo
  • 北京织梦网站建设微信广告平台
  • 无锡 网站建设百度下载安装最新版
  • 视频模板网站成都网站搭建优化推广
  • 学做软件的网站网络营销推广要求
  • 建凡网站长沙seo免费诊断
  • 专业的西安免费做网站最新新闻国内大事件
  • 网站建设技术合作合同恩城seo的网站
  • 图书网站建设百度推广时间段在哪里设置
  • wp网站模板安装微指数
  • web用框架做网站成都seo推广
  • 冠县做网站推广线上广告推广平台
  • 网站建设技术服务费记什么科目易推客app拉新平台
  • 百度权重1网站推广优化怎么做最好
  • 兰州做网站哪家专业云盘网页版登录
  • 昆明网站建站搜索引擎推广有哪些平台
  • wordpress文字修改aso优化师
  • 怎么做网站后期维护2022最近比较火的营销事件
  • 如何在天气预报网站做引流电商如何推广自己的产品
  • 成功网络营销案例百度seo推广计划类型包含