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

南宁市保障住房建设管理服务中心网站nba赛季排名

南宁市保障住房建设管理服务中心网站,nba赛季排名,学校网站建设工作总结,小程序源码怎么使用的前言 对于这两个容器适配器的模拟实现非常简单,因为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/290397.html

相关文章:

  • 手机可以登录国家开发银行网站吗百度软件商店
  • 新闻类网站建设二级域名和一级域名优化难度
  • 东莞网站建设电镀挂具seo导航站
  • 培训机构做网站宣传企业关键词排名优化网址
  • 会议网站建设方案百度seo报价
  • 中国建设银行网站 个人什么软件可以搜索关键词精准
  • 爱辉网站建设接外贸订单的渠道平台哪个好
  • vue 做双语版网站注册城乡规划师教材
  • 做网站asp用什么软件代写文案的软件
  • 网站搭建设计方案分销系统
  • 南山网站建设公司磁力链搜索引擎入口
  • 做网站卖东西赚钱么seo建设招商
  • vs2013网站开发代码长沙网站优化效果
  • 网络策划是什么青岛网络优化代理
  • 中企动力网站后台网络服务器
  • 搭建网站首页长沙做网站推广
  • dw+如何做自适应网站商业软文怎么写
  • 律师做哪个网站好站长工具爱站网
  • 有赞可以做独立网站吗如何提高百度关键词排名
  • 有什么网站帮做邀请函设计的百度关键词排名批量查询工具
  • the7做的网站seo推广外包报价表
  • 深圳购物网站建设seo免费培训教程
  • 北京品牌网站设计佛山网站建设解决方案
  • 2014网站怎么备案注册商标查询官网入口
  • 返利网站开发一般要多少钱百度培训
  • 设置网站开场动画包头seo
  • 无锡网站建设 app百度收录查询
  • 卫生计生加强门户网站建设seo关键词排名优化要多少钱
  • 哪个网站是vue做的手机如何制作网站教程
  • 网站做淘宝客赚钱吗简述提升关键词排名的方法