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

国外做美食的网站有哪些互联网运营自学课程

国外做美食的网站有哪些,互联网运营自学课程,英文网站做翻译接单,东莞松山湖风景区目录 前言 数据结构 deque vector和list的优缺点 push pop top size empty 完整代码 前言 stack类就是数据结构中的栈 C数据结构:栈-CSDN博客 stack类所拥有的函数相比与string、vector和list类都少很多,这是因为栈这个数据结构是后进先出的…

目录

前言

数据结构

deque

vector和list的优缺点

push

pop

top

size

empty

完整代码


前言

stack类就是数据结构中的栈

C数据结构:栈-CSDN博客

stack类所拥有的函数相比与string、vector和list类都少很多,这是因为栈这个数据结构是后进先出的,它必须被有所限制,所以所能用的函数只需要那几个足矣

栈可以用顺序表来实现,也可以用链表来实现,我们只需要控制它先进先出的特性即可,用什么容器实现取决于个人

因为我们前面实现了vector和list类,所以再实现stack类就容易很多了,只需要复用vector和list容器内的函数即可

数据结构

template<class T, class Container = std::deque<T>>
class stack
{
public:private:Container _con;
};

这里的模板有两个,T是栈的类型,Container表示的是所需要使用哪个容器来实现这个栈

我们需要用这个Container里面的成员函数来复用从而轻松的实现这个栈

这里的Container默认是deque

deque

deque(双端队列)也是STL中的一个容器,它是vector和list的结合

vector和list的优缺点

vector优点:

1. 随机访问效率高

2. 在内存中连续存储,缓存命中率高

vector缺点:

1. 插入和删除效率低

2. 空间分配不灵活(利用率低)

list优点:

1. 插入和删除效率高

2. 空间利用率高

list缺点:

1. 访问数据速度慢

2. 缓存利用率低(空间不连续,缓存命中率低)

为什么说deque是vector和list的结合?

下面是deque的数据结构图片

deque有n个buffer缓冲区(个数取决于数据个数)

这个缓冲区比list的空间大,像是一个小型数组,这个数组由中控器控制

而中控器可以通过一个数组来存储一个个的指针,这些指针又指向一个个缓冲区,所以它能够控制每一个缓冲区

iterator迭代器的cur、first和last来控制缓冲区的数据,node则表示是哪一个缓冲区

deque总结:

1. deque的头尾插入效率高

2. 下标的随机访问效率也还可以

3. 中间插入删除的效率很低(O(N))

push

void push(const T& x)
{_con.push_back(x);
}

栈的push就是插入到最后的位置,所以只需要复用容器中的push_back函数即可

deque、vector和list都有这些函数,所以这三个容器都可以用来实现stack类

pop

void pop()
{_con.pop_back();
}

栈的pop就是尾删,所以只需要复用pop_back函数即可 

top

const T& top() const
{return _con.back();
}

栈的top就是取尾部数据,返回back函数即可 

size

size_t size() const
{return _con.size();
}

栈的size就是取得栈的数据个数,返回容器的size函数即可 

empty

bool empty() const
{return _con.empty();
}

栈的empty就是判断栈是否为空,返回empty函数即可

只要上述的函数名哪个类中有,并且功能相同,就可以使用那个类来完成stack的实现

完整代码

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

http://www.hkea.cn/news/878862/

相关文章:

  • 建设网站考虑因素关键词优化是怎么弄的
  • 陕西营销型网站建设推广普通话的内容简短
  • 做配电箱的专门网站百度指数属于行业趋势及人群
  • 学做网站的网站重庆seo整站优化报价
  • 保定网站设计概述seo推广软件排名
  • 查pv uv的网站网络营销推广服务
  • 怎样让客户做网站优化 保证排名
  • 企业营销型网站做的好网络营销的有哪些特点
  • 网站开发 合同兰州快速seo整站优化招商
  • 网站开发技术现状深圳网络营销推广培训
  • 知名网络公司有哪些河北网站seo
  • 学做网站多少钱关键词难易度分析
  • 传奇如何做网站网站建设策划书案例
  • 龙岗 网站建设深圳信科最好用的搜索神器
  • 动态网站开发日志重庆seo整站优化报价
  • 魔站网站建设微信公众号运营推广方案
  • 好的网站建设公司营销推广外包公司
  • 教育机构做网站素材长尾关键词爱站
  • 做网站选什么系统企业网站seo推广
  • 山东省南水北调建设管理局网站腾讯网qq网站
  • 菏泽做网站公司sem网络营销
  • 专业建站外包兰州网络优化seo
  • 企业邮箱腾讯杭州seo按天计费
  • 政府网站建设先进个人事迹互动营销
  • 网站建设之织梦模板做国外网站
  • 小程序电商模板seo关键词排名优化品牌
  • 泉州网站优化排名百度关键字优化价格
  • 上海网站建设好处win优化大师官网
  • 适合毕设做的简单网站初学seo网站推广需要怎么做
  • 想把书放到二手网站如何做深圳seo关键词优化