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

主流网站关键词排名jsp 响应式网站模板下载

主流网站关键词排名,jsp 响应式网站模板下载,仓山福州网站建设,网站开发常用形状文章目录 如何实现?实现stack实现queue总结 如何实现? 首先我们看看官网上的stack,官网上的stack是用deque作为模版的缺省值去实现的,deque是什么? deque其实就是双端队列,双端队列,顾名思义&am…

文章目录

  • 如何实现?
  • 实现stack
  • 实现queue
  • 总结

在这里插入图片描述

如何实现?

在这里插入图片描述
首先我们看看官网上的stack,官网上的stack是用deque作为模版的缺省值去实现的,deque是什么?
deque其实就是双端队列,双端队列,顾名思义,就是可以队尾入数据队尾出数据,也可以从队头出数据和队头入数据,让我们看看双端队列的接口,可以去看看官网看看(双端队列)。
双端队列就类似于队列和顺序表的结合版,不仅可以首插和尾插还支持[]随机访问。

实现stack

在学习C++的时候我们知道函数有缺省参数,那类比过来,其实模版也有缺省参数,我们马上要实现的stack就有模版参数。
按照以前我们C语言写的stack我们应该用数组手搓一个,但是现在我们有stl库了,我们可以直接复用里面写好的容器,也就是我们上面介绍的deque。

 template<class T, class Con = deque<T>>class stack{public:void push(const T& x){_c.push_back(x);}void pop(){_c.pop_back();}T& top(){return _c.back();}const T& top()const{return _c.back();}size_t size()const{return _c.size();}bool empty()const{return _c.empty();}private:Con _c;};

我们直接复用STL里写好的接口,其实上面这种模式是一种设计方式,被称为容器适配器。
容器适配器的优点:

  1. 简化使用
    容器适配器提供了统一的接口,使得不同类型的容器类更易于使用。例如,std::stack、std::queue 和 std::priority_queue 通过封装底层容器类,提供了一组简洁明了的接口,用户无需关注底层实现细节即可使用这些容器。

  2. 隐藏实现细节
    容器适配器隐藏了底层容器类的实现细节。用户只需关注适配器提供的接口,而不需要了解底层容器类的具体实现。这有助于提高代码的可读性和可维护性。

  3. 提高代码可维护性
    由于容器适配器提供了统一的接口和抽象层,代码的可维护性得到了提高。如果底层容器类发生了变化,只需修改容器适配器的实现,而不需要修改使用适配器的代码。

  4. 代码复用
    通过使用容器适配器,可以实现代码复用。适配器封装了常见的容器操作,如 push、pop、top 等,避免了重复实现这些操作的需求,提高了代码的复用性。

实现queue

由于deque的优点,我们也可以用deque做queue的模版缺省参数,queue的接口很简单,queue的性质就是先进先出,所以根据queue的性质我们很容易可以模拟出queue

  template<class T, class Con = deque<T>>class queue{public:void push(const T& x){_c.push_back(x);}void pop(){_c.pop_front();}T& back(){return _c.back();}const T& back()const{return _c.back();}T& front(){return _c.front();}const T& front()const{return _c.front();}size_t size()const{return _c.size();}bool empty()const{return _c.empty();}private:Con _c;};
};

总结

通过对 C++ 中 stack 和 queue 的模拟实现,我们深入了解了容器适配器的工作原理和优势。这些适配器通过封装底层容器,提供了简洁而统一的接口,使得数据结构的操作变得更加直观和便捷。我们的模拟实现展示了如何利用已有的容器类来构建自定义的数据结构,同时也强调了代码复用和隐藏实现细节的重要性。

在实际开发中,选择合适的数据结构和容器适配器能够显著提升代码的可读性、可维护性和性能。因此,熟练掌握和灵活运用这些基础工具,是每一个 C++ 开发者必备的技能。希望这篇博客能够帮助读者更好地理解 stack 和 queue 的实现原理,并在实际项目中应用这些知识,实现更加高效和优雅的代码。

感谢大家的阅读,如果你有任何疑问或建议,欢迎在评论区留言讨论。

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

相关文章:

  • jsp做网站好不好电气工程专业毕业设计代做网站
  • 网站建设资金管理办法建站网址
  • 深圳做营销网站的公司哪家好顺德家居企业网站建设
  • 咸阳网站建设专业公司办公用品网站建设市场定位
  • 在百度上做网站多少钱微电影制作
  • 网站开发作品南通制作网站公司
  • 做网站工资多少钱企业核名查询系统是哪个
  • ip分享网站上海的外贸网站建设公司价格
  • 怎么自己创建网站或者appwordpress开玩笑 呵
  • 网站开发项目答辩视频石家庄网站设计工作室
  • 建设部网站四库一平台个人网站设计的意义
  • 网站建设费计入什么科目比较好石家庄网站外包
  • 中国社交网站做多外国人的企业网站管理系统站长之家
  • php网站怎么做的做任务兼职赚钱的网站有哪些
  • 青岛福瀛建设集团网站大朗网站建设
  • 反邪手机网站建设方案做英文网站的标准字体
  • 免费qq空间网站网站建设推广代理
  • 微信公众号开发网站开发泸州作网站建设联系电话
  • 和县网站制作南宁江南区网站制作多少钱
  • 广州印刷网站建设作风建设年活动网站
  • 佛山提供网站设计方案公司国内优秀网页设计案例
  • 网站改版需要重新备案吗php+mysql网站开发
  • 公司做网站都需要什么网络新项目首码发布渠道
  • 建设中网站源码如何做国外外贸网站
  • 网站建设外文文献翻译自建网站支付问题
  • steam官方网站下载wordpress自动伪原创
  • 网站建设效果瑞安市公用建设局网站
  • 做商城网站价格ppt一键优化
  • 广东网站建设公司网络服务有哪些网站可以做外贸
  • php婚庆网站源码阿里云域名注册邮箱