有谁能总结一下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-jarC++中怎么创建一个容器类?
#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来保证可靠性
RepriseHosting是成立于2012年的国外主机商,提供独立服务器租用和VPS主机等产品,数据中心在美国西雅图和拉斯维加斯机房。商家提供的独立服务器以较低的价格为主,目前针对西雅图机房部分独立服务器提供的优惠仍然有效,除了价格折扣外,还免费升级内存和带宽,商家支持使用支付宝或者PayPal、信用卡等付款方式。配置一 $27.97/月CPU:Intel Xeon L5640内存:16GB(原...
LOCVPS(全球云)发布了新上韩国机房KVM架构主机信息,提供流量和带宽方式,适用全场8折优惠码,优惠码最低2G内存套餐月付仅44元起。这是一家成立较早的国人VPS服务商,目前提供洛杉矶MC、洛杉矶C3、和香港邦联、香港沙田电信、香港大埔、日本东京、日本大阪、新加坡、德国和荷兰等机房VPS主机,基于KVM或者XEN架构。下面分别列出几款韩国机房KVM主机配置信息。韩国KVM流量型套餐:KR-Pl...
ZJI本月新上线了香港葵湾机房站群服务器,提供4个C段238个IPv4,支持使用8折优惠码,优惠后最低每月1400元起。ZJI是原Wordpress圈知名主机商家:维翔主机,成立于2011年,2018年9月更名为ZJI,提供中国香港、台湾、日本、美国独立服务器(自营/数据中心直营)租用及VDS、虚拟主机空间、域名注册等业务,所选数据中心均为国内普遍访问速度不错的机房。葵湾二型(4C站群)CPU:I...
容器类为你推荐
isbackgroundbokeh是什么意思createfile失败CreateFile失败,代码5拒绝访问(高分在线求助!!!)avc是什么格式XVID/MPEG/AVC都是什么意思啊shoujiao如何区分是不是颈椎病?云输入法如何使用QQ云输入法?sms是什么短信确认码是什么特斯拉model3降价特斯拉model 3中国有补贴吗erp系统教程ERP系统怎么使用东兴证券网站东兴证券交易软件如何操作?怎样删除聊天记录怎么批量清除微信聊天记录
英文域名 网通vps 免费申请域名 ftp空间 国内免备案主机 t牌 vultr美国与日本 网通代理服务器 qq数据库下载 警告本网站美国保护 合租空间 699美元 免费防火墙 美国网站服务器 vip域名 in域名 华为云服务登录 申请网站 789 国外在线代理服务器 更多