C++Primer笔记之顺序容器的使用详解

2016-02-19 09:36 5 1 收藏

给自己一点时间接受自己,爱自己,趁着下午茶的时间来学习图老师推荐的C++Primer笔记之顺序容器的使用详解,过去的都会过去,迎接崭新的开始,释放更美好的自己。

【 tulaoshi.com - 编程语言 】

  顺序容器,它将单一类型元素聚集起来成为容器,然后根据位置来存储和访问这些元素,这就是顺序容器。标准库里定义了三种类型:vector(支持快速随机访问)、list(支持快速插入、删除)、deque(双端队列)容器只定义了少量操作,大多数额外的操作由算法库提供。容器内元素的类型约束;1、元素类型必须支持赋值运算;2、元素类型的对象必须可以复制。这是容器元素类型的最低要求,如果想支持一些其他特殊要求,则必须具备相关的性质。

可以定义容器的容器vector vectorint lines;//必须使用" "中间的空格,否则会出现变异错误

迭代器运算:

  关系操作符只适用于vector和deque容器,它们可以根据元素位置直接有效地访问指定的容器元素。而list容器的迭代器既不支持算术运算(加法或者减法),也不支持关系运算(=,,=,),它只提供前置和后置的自增、自减运算以及相等(不等)运算。

迭代器范围:

  c++使用一对迭代器标记迭代器范围,通常命名为first和last或beg和end。该范围内的元素包括迭代器first指向的元素,以及从first开始一直到迭代器last指向的位置之前的所有元素,此类元素范围称为左闭合区间[first,last)。

顺序容器的操作:

  在容器中添加元素;在容器中删除元素;设置容器大小;获取容器内的第一个和最后一个元素。对于begin()、end()、rbegin()、 rend()四个操作,均有const版本。如果容器时const,则其返回类型要加上const_前缀。c.push_back(t) 在容器c的尾部添加值为t的元素,返回void类型。c.push_front(t) 在容器c的前端添加值为t的元素,返回void类型。但是只有list和deque具有这样的性质。
代码如下:

//容器的顺序遍历
vectorint::reverse_iterator iterReverse=vect.rbegin();//定义反向迭代器while(iterReverse!=vect.rend())
{
    cout*iterReverseendl;
    iterReverse++;
}
vectorint::iterator iter = vect.begin();//定义正向迭代器
while(iter!=vect.end())
{
    cout*iterendl;
    iter++;
}

  在容器中的指定位置添加元素:使用insert函数:由于迭代器可能指向超出容器末端的下一位置没这事一个不存在的元素,因此insert函数是在其指向位置之前而非其后插入元素。mylist.insert(iter,element);
代码如下:

//获取中心位置迭代器,需要注意的list不允许如下的迭代器的加法
vectorint::iterator middle=vectCpy.begin()+vect.size()/2;
vectCpy.insert(middle,1001);//在中间位置添加一个元素 

  插入一段元素:
代码如下:

vectCpy.insert(vectCpy.begin(),10,9);//在第一个元素后面添加10个初值为9的元素
int num[3]={555,666,777};
vectCpy.insert(vectCpy.end(),num,num+3);//在vectCpy后面加入一段来自num数组里的元素
vectCpy.insert(vectCpy.end(),vect.begin(),vect.end());//在vectCpy后加入一段来自迭代器对间的元素

  需要注意的是,添加元素可能会导致某些或全部迭代器失效,假设所有迭代器失效是最安全的做法。不要存储end操作返回的迭代器,为了避免存储end迭代器,可以在每次做完插入运算重新计算end迭代器值。

关键概念:容器元素都是副本在容器中添加元素时,系统是将元素值复制到容器里。类似的,使用一段元素初始化新容器时,新容器存放的事原始元素的副本。本复制的原始值与新容器中的元素各不相干,此后,容器内元素值发生变化时,被复制的原值不会受到影响,反之亦然。

容器的比较:

  比较的容器必须具有相同的容器类型,而且其元素类型也必须相同。容器的比较式基于容器内元素的比较。两个容器具有相同的长度而且所有的元素都相等,那么这两个容器就相等。如果两个容器长度不相等,但较短的容器中所有元素都等于较长容器中对应的元素,则称较短的容器小于另一个容器。如果两个容器都是对方的初始子序列,则它们的比较结果取决于所比较的第一个不相等的元素。
代码如下:

vectorint vect;
vect.push_back(1);
vect.push_back(2);
vect.push_back(3);
vectorint vectCpy(vect);
if(vectCpy==vect) cout"Equal"endl;
else cout"Not Equal"endl;

容器大小的操作:

  容器类型提供resize函数来改变容器所包含的元素个数。如果当前的容器长度大于新的长度值,则该容器后部的元素会被删除,如果当前的容器长度小于新的长度值,则系统会在该容器后部添加新元素。resize操作可能会使迭代器失效。例子:
代码如下:

listint ilist(10,2);//10个元素容器,初始值均为2
ilist.resize(15);//在原有基础上,再后面添加5个元素,初始值为0
ilist.resize(25,-1);//在上行的基础上,再后面再添加10个元素,值为-1
ilist.resize(5);//在ilist的后部删除20个元素

访问元素:

  如果容器非空,那么容器类型的front和back成员将返回容器内第一个或最后一个元素的引用
代码如下:

int &ref=vect.front();//front和back返回容器内第一个或最后一个元素的引用
ref=1000001;//改变引用的元素,vect内元素的值也会改变
coutvect[0]" "vect.at(1)endl;//只适用于vector和deque,如果给出的下标无效,则会发生outOfRange的异常

删除元素:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  pop_front和pop_back函数用于删除容器内的第一个和最后一个元素。

  删除一个或者一段元素更通用的方法是用erase操作,有两个版本:删除由一个迭代器指向的单个元素,或删除由一对迭代器标记的一段元素。erase返回一个迭代器,它指向被删除元素或元素段后面的元素。通常,必须在容器中查找要删除的元素后,才使用erase操作。寻找一个指定元素最简单的方法,是使用标准库中的find方法。必须包含头文件algorithm.h
代码如下:

#includealgorithm
listint::iterator searchIter= find(mylist.begin(),mylist.end(),1233);
if(searchIter!=mylist.end())//有可能找不到
{
mylist.erase(searchIter);
}


  删除容器内所有元素:mylist.clear()或者mylist.erase(mylist.begin(),mylist.end());

容器的选用:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  vector和deque容器提供了对元素的快速随机访问,但付出的代价是,在容器的任意位置插入或删除元素,比在容器尾部插入和删除元素的开销更大。list类型在任何位置都能快速插入和删除,但付出的代价是元素的随机访问开销较大。其原因就是在内部实现的数据结构中,一个是在内存中顺序地址分批的,而另一个是在类似链表的方式,随机地址分配的,所以导致性质的不同。

来源:http://www.tulaoshi.com/n/20160219/1591395.html

延伸阅读
大师级经典的著作,要字斟句酌的去读,去理解。以前在看K&R的The C Programming Language(SecondEdition) 第1.5节的字符输入/输出,被getchar()和EOF所迷惑了。可能主要还是由于没有搞清楚getchar()的工作原理和EOF的用法。因此,感觉很有必要总结一下,不然,很多琐碎的知识点长时间过后就会淡忘的,只有写下来才是最好的方法。 其实,getchar...
学过数学的人都知道,高斯消元法是解线性方程组是,算法很简单,但过程很复杂,这就是我在网上找不到免费的且正确的高斯消元法的原因了。所以我下决心自己编,结果I do it. 高斯消元法的用途很广,它是解决数学问题最重要的方法之一,在《计算方法》这本书的第一章就讲的是高斯消元法,很多问题最终归结为解线性方法组。 因为我是个编程初学...
标签: 手机游戏 IOS
《神仙道》攻略之新版阵法出手顺序规则详解 在《神仙道》中阵法是一个很有针对性的技巧。实力相同情况下一个克制对方阵法的布阵可以轻松无损完虐对手不损自己分毫。但同样实力比对方强如果被针对阵型也容易出现失手被击败的命运。新版出手规则和旧版略有不同,主要体现在对死伤伙伴的一方吃的亏会降低一些。这样秒杀的效果就会降低一些增加的游...
标签: 护肤品
洁面产品 护肤保养之前,清洁永远是第一步,不要小看清洁,非常重要! 化妆水 化妆水的作用在于再次清洁以恢复肌肤表面的酸碱值,并调理角质层,使肌肤更好地吸收,为使用保养品作准备。伊伊建议油性皮肤使用紧肤水,健康皮肤使用爽肤水,干性皮肤使用柔肤水,混合皮肤T区使用紧肤水,敏感皮肤选用敏感水、修复水。 肌底液 肌底液的...
下面是c++的源码: 代码如下: class X  { public:    int i;    int j;    ~X() {} }; void f(X x) {   X x1;   x.i = 1;   x.j = 2; } int main() {     f(X()); } 下面是main函数的汇编码: 代码如下: _main    PROC ; 15   : int ma...

经验教程

595

收藏

79
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部