容器类关于C++中怎么创建一个容器类?

容器类  时间:2021-06-29  阅读:()

有谁能总结一下C++容器类什么情况下会经常用到

容器用来存储数据的,数据可以是用户自定义类型(对象),也可以是预定义类型。

c++中的容器主要使用如vector,list (顺序容器) 这些都是已经封装好了的,包含头文件"vector","list",通过迭代器iterator访问容器中的数据,map,set(关联容器),关联容器map键值对形式出现key-value,key唯一,mutimap多映射可以不唯一;set是一个单一值的集合,如1,2,3,4 顺序容器:vector,list 分别举例 对比 vector容器的特点:在内存中是一片连续的存储区域,初始化的时候,可以指定容量,比如如果定义容量50 的容器存储 60个string对象,由于初始容量不足60,容器将会重新定义一个容量是原来的2倍新容器,然后拷贝原容器的对象到新容器. 读取速度快,插入删除效率低.如果仅仅在容器头或尾部 进行增删改,推荐使用deque,专门提供了对首尾的操作. list容器特点:相当数据结构的链表,不是一个连续的存储区域,插入,删除很方便,但是查询速度慢 vector vec 就是定义了一个vector容器,可以通过 vec.push_back(), push_font(),insert(position,value) 想vector中添加一个指定值 list ilist list ilist(20 -1) 初始20个值为-1的list 然后操作可以参考这些这些类封转的方法。

关联容器:set map mutimap mutiset key-->value形式 1--1 2--2 3--3 set 形式 1234,键值唯一; 具体容器的操作方法,可以调用其成员函数.

关于容器类的英文单词(带中文意思的)

碟子: small dish/ dish 盘子: tray 盆: basin 锅: pan/ pot/ boiler 碗: bowl 杯子: cup/ glass 缸: vat/ jar 瓢: ladle/ dipper 瓶: bottle /vase/ pitcher 罐子: jar /jug/ pitcher/ pot 鼎: tripod 盅: cup 壶: pot/kettle 桶: pail /bucket/barrel/bin 樽: goblet/ bottle/ wine-jar

C++中怎么创建一个容器类?

#include?<algorithm> struct?Person { //...Person成员变量 void?print() { //todo?输出Person信息 } }; class?PersonSet { public: enum{DEFAULT_CAPACITY?=?4}; typedef?Person ElemType; typedef?int SizeType; PersonSet(); ~PersonSet(); void?add(ElemType&?person); //往容器中加入一个对象 //这里返回Person&是不合理的(如果最后没有元素了,这个空的引用要怎么返回???)。

//可以改成Person*或者void void?removeElement(); //删除容器中的最后一个对象 void?removeElement(int?const&index);//删除容器中指定位置的对象 int?getSize()?const;//获取当前容器中有多少个对象 void?print()?const;//打印容器中各个对象的信息 protected: void?checkGrow(); void?checkShrink(); void?grow(); void?shrink(); protected: ElemType** _elements; //为什么要用二级指针,只是为了考察它的用法??? SizeType _capacity; SizeType _size; int _index; //index有何用??? }; PersonSet::PersonSet() :_capacity(DEFAULT_CAPACITY) ,_size(0) ,_index(0) { _elements?=?new?ElemType*; *_elements?=?new?ElemType[_capacity]; } PersonSet::~PersonSet() { delete?[]?*_elements; delete?_elements; } void?PersonSet::add(ElemType&?person) { checkGrow(); (*_elements)[_size++]?=?person; } void?PersonSet::removeElement() { _size--; checkShrink(); } void?PersonSet::removeElement(int?const&index) { if(index?<?0?||?index?>?_size) return; //元素依次前移 std::copy(*_elements+index+1,?*_elements+_size-1,?*_elements+index); _size--; checkShrink(); } int?PersonSet::getSize()?const { return?_size; } void?PersonSet::print()?const { for(SizeType?i?=?0;?i?<?_size;?i++) { (*_elements)[i].print(); } } void?PersonSet::checkGrow() { if(_size?==?_capacity) grow(); } void?PersonSet::checkShrink() { if(_size?<?_capacity?/?2) shrink(); } void?PersonSet::grow() { _capacity?>>=?2; ElemType*?p?=?new?ElemType[_capacity]; std::copy(*_elements,?*_elements?+?_size?-?1,?p); delete?[]?*_elements; *_elements?=?p; } void?PersonSet::shrink() { _capacity?<<=?2; }

关于C++中怎么创建一个容器类?

因为我们使用数组实现的,为了防止过多的分配释放内存,就有了一个_capacity和_size,我们可以通过_size来保证数据的可靠性,所以_size--就可以了. 通过重载[],我们可以通过object.[x],判断x是否大于_size来保证可靠性

DiyVM:50元/月起-双核,2G内存,50G硬盘,香港/日本/洛杉矶机房

DiyVM是一家比较低调的国人主机商,成立于2009年,提供VPS主机和独立服务器租用等产品,其中VPS基于XEN(HVM)架构,数据中心包括香港沙田、美国洛杉矶和日本大阪等,CN2或者直连线路,支持异地备份与自定义镜像,可提供内网IP。本月商家最高提供5折优惠码,优惠后香港沙田CN2线路VPS最低2GB内存套餐每月仅50元起。香港(CN2)VPSCPU:2cores内存:2GB硬盘:50GB/R...

安徽BGP云服务器 1核 1G 5M 29元/月 香港云服务器 1核 1G 19元首月 麻花云

麻花云怎么样?麻花云公司成立于2007年,当前主打产品为安徽移动BGP线路,数据中心连入移动骨干网。提供5M,10M大带宽云主机,香港云服务器产品,数据中心为香港将军澳机房,香港宽频机房 cn2-GIA优质线路、采用HYPER-V,KVM虚拟技术架构一、麻花云官网点击直达麻花云官方网站合肥网联网络科技有限公司优惠码: 专属优惠码:F1B07B 享受85折优惠。最新活动 :双11 云上嗨购 香港云主...

TMTHosting:夏季优惠,美国西雅图VPS月付7折,年付65折,美国服务器95折AS4837线路

tmthosting怎么样?tmthosting家本站也分享过多次,之前也是不温不火的商家,加上商家的价格略贵,之到斯巴达商家出现,这个商家才被中国用户熟知,原因就是斯巴达家的机器是三网回程AS4837线路,而且也没有多余的加价,斯巴达家断货后,有朋友发现TMTHosting竟然也在同一机房,所以大家就都入手了TMTHosting家的机器。目前,TMTHosting商家放出了夏季优惠,针对VPS推...

容器类为你推荐
instagram电脑版苹果macbook pro做摄影拍照后期有什么优势吗?为什么很多摄影师用它?和thinkpad W系列比呢?短信营销方案家装短信营销如何进行才有效?youtube创始人卜秋静 有关生平介绍oledbdatareaderDataReader和IDataReader的区别?pat是什么格式photoshop填充图案是pat格式,需用什么软件打开?请高人指点,谢谢~java程序员招聘java程序员学出来工作好不好找,工资咋样?腾讯合作伙伴大会从微信同程旅行买的机票怎么打印电子发票?腾讯合作伙伴大会如何成为腾讯渠道合作伙伴?防火墙技术应用在网络支付流程中,防火墙技术与数据加密技术应用则重点有什么不同?怎么查微信注册时间怎么查看自己的微信号用了多久
提供香港vps 有益网络 刀片服务器是什么 200g硬盘 ebay注册 免费asp空间申请 lamp是什么意思 工信部icp备案查询 电信主机托管 标准机柜 美国西雅图独立 dns是什么意思 瓦工招聘 天翼云主机 56折扣网 竞彩论坛空间 双宿主机防火墙 北京摇号申请网站入口 自住型商品房申请网站 lickme 更多