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

南宁市保障住房建设管理服务中心网站企业微信会话内容存档

南宁市保障住房建设管理服务中心网站,企业微信会话内容存档,国外wordpress电影模板,帝国网站管理系统教程前言 对于这两个容器适配器的模拟实现非常简单,因为stack和queue只是对其他容器的接口进行了包装,在STL中,若我们不指明用哪种容器作为底层实现,栈和队列都默认是又deque作为底层实现的。 也就是说,stack和queue不管是…

前言

对于这两个容器适配器的模拟实现非常简单,因为stack和queue只是对其他容器的接口进行了包装,在STL中,若我们不指明用哪种容器作为底层实现,栈和队列都默认是又deque作为底层实现的。

也就是说,stack和queue不管是用哪种容器实现出来的,实际上定义出来的都是对容器进行了封装。

stack的模拟实现

所以我们知道了容器适配器实际上是对其他容器的封装之后,我们实现的时候就只需要调用底层容器的各个成员函数实现stack的接口就行:

成员函数及作用模拟实现方法
push(元素入栈)调用指定容器的push_back
pop(元素出栈)

调用指定容器的pop_back

top(获取栈顶元素)调用指定容器的back
size(获取栈中有效元素个数)调用指定容器的size
empty(判断栈是否为空)调用指定容器的empty
swap(交换两个栈中的数据)调用指定容器的swap

模拟实现的代码如下:

#pragma once
#include<queue>
#include<iostream>
using namespace std;
namespace CYF
{template<class T,class Container=std::deque<T>>class stack{public:void push(const T& val){_con.push_back(val);}void pop(){_con.pop_back();}T& top(){return _con.back();}size_t size(){return _con.size();}bool empty(){return _con.empty();}void swap(stack<T,Container>& st){_con.swap(st._con);}private:Container _con;};
}

queue模拟实现

同样的我们也通过调用指定容器的成员函数来模拟实现queue。

成员函数及作用模拟实现方法
push(元素队尾入队)调用指定容器的push_back
pop(元素队头出队)调用指定容器的pop_front
front(获取队头元素)调用指定容器的front
back(获取队尾元素)调用指定容器的back
size(获取队列中有效数据个数)调用指定容器的size
empty(判断队列是否为空)调用指定容器的empty
swap(交换两个队列中的数据)调用指定容器的swap

模拟实现的代码如下:

#pragma once
#include<iostream>
#include<list>
#include<queue>
using namespace std;namespace CYF
{template<class T,class Container=deque<T>>class queue {public:void push(const T& val){_con.push_back(val);}void pop(){_con.pop_front();}T& front(){return _con.front();}T& back(){return _con.back();}size_t size(){return _con.size();}bool empty(){return _con.empty();}void swap(queue<T,Container>& q){_con.swap(q._con);}private:Container _con;};
}

下面这是test.cpp中的测试代码:

#include"myStack.h"
#include"myQueue.h"
void test1()
{CYF::stack<int, vector<int>> st;st.push(1);st.push(2);st.push(3);st.push(4);while (!st.empty()){cout << st.top() << " ";st.pop();}cout << endl;
}void test2()
{CYF::queue<int, list<int>> q;q.push(1);q.push(2);q.push(3);q.push(4);while (!q.empty()){cout << q.front() << " ";q.pop();}cout << endl;
}int main()
{//test1();test2();return 0;
}

以上就是本篇的全部内容,谢谢大家!

http://www.dtcms.com/wzjs/396360.html

相关文章:

  • 中国建设部官方网站监理转注册电商推广
  • 软件定制需要多少钱某网站seo诊断分析
  • 品牌网站建设专业定制seo长尾关键词优化
  • wordpress+用户前台抖音关键词优化排名
  • 做网站多少钱西宁君博示范福州seo网站管理
  • 网站什么引导页网店培训机构
  • 网站建设热门吗东莞百度seo关键词优化
  • 大连网站建设优化常州seo建站
  • 网站怎么做实名认证网站开发
  • 西安代做毕业设计网站百度竞价是什么意思
  • 我要自学网网站开发seo百度排名优化
  • 动态网站成品网络营销的核心是什么
  • 行业网站推广方案企业推广公司
  • 全运会网站的建设北京外包seo公司
  • 淘客网站推广免备案网络推广合作协议范本
  • 有什么网站是可以做日语题自己有域名怎么建网站
  • axure做网站下拉菜单免费十大软件大全下载安装
  • 中国采购网关键词优化排名查询
  • 网站建设合同 附件seo代码优化包括哪些
  • 免费建设外贸网站怎样在百度上发帖子
  • 哪个网站能学做微商目前搜索引擎排名
  • 国外网站代理请输入搜索关键词
  • 吉安市建设局网站淘宝自动推广软件
  • 搭建微信网站怎么做做个小程序需要花多少钱
  • 上海做网站公司排名常用的网络营销工具有哪些
  • 百度网站权重查询搜索引擎优化不包括
  • 公司网站怎么做关键词郑州seo优化阿亮
  • 山东营销网站建设联系方式线上营销推广方案
  • 沧州网站建设价格百度竞价推广代理
  • 做网站时的注册权起到什么作用关键词推广方式