参考:http://www.weixueyuan.net/view/6402.html

总结:

  vector可以理解为可以在两端插入、删除数据的数组,它提供了丰富的成员函数,用于操作数据。

    begin()返回的是一个迭代器,如果容器不为空,则返回的迭代器指向容器的第一个元素;如果容器为空,则返回的迭代器指向容器尾部之后的位置。

    end()函数同样返回的是一个迭代器,该迭代器指向的是容器尾部之后的位置。当容器为空时,begin()函数和end()函数都指向同一个位置。

    调用insert函数时,如果不是在容器尾部插入元素,则需要将所插入位置以后的元素都向后移一位,然后再将需要插入的元素插入到当前位置。

    erase函数删除容器中的元素

  vector和deque不同。vector说到底是个数组,在非尾部插入元素都需要移动其它元素,

  而deque则不同,它是一个可以操作数组头部和尾部的数组,因此在头部或尾部插入或删除数据,其处理效率都是一样的。

  当我们需要频繁在头部和尾部插入或删除数据,则deque优于vector。

  通常每定义一个容器,就会有一个与容器数据类型相关的迭代器。

  如果我们不需要修改容器中的元素,仅仅只是进行访问的话,则可以定义为const_iterator。

  当我们需要获得当前迭代器所指的元素时,我们可以用取址操作符“*”来操作迭代器,“*iter”就为迭代器所指向的元素。

  list并没有重载下标操作符,因而不能根据下标进行直接访问。

  list容器是一个双向链表,因此在容器中的任何位置插入元素,都不需要移动其它元素,因此执行效率是稳定的。

------------------

我们以vector、deque和list为例介绍基本序列式容器。我们先来看一个关于vector的例子。

例1:

#include <iostream>
#include <vector>
using namespace std; int main()
{
vector< int > num;
num.push_back( );
num.insert(num.begin(), );
num.insert(num.end(), );
num.push_back( );
num.push_back( );
cout << num.size() << endl;
for(int i = ; i < num.size(); i++)
cout << num[i] << " ";
cout << endl;
num.erase(num.begin());
cout << num.size() << endl;
for(int i = ; i < num.size(); i++)
cout<< num[i] <<" ";
cout << endl;
return ;
}

vector可以理解为可以在两端插入、删除数据的数组,它提供了丰富的成员函数,用于操作数据。在本例中我们加入了头文件vector,在使用vector时必须包含该头文件。

我们接着来看一下主函数。在主函数中我们定义了一个vector类的int型实例num,需要注意的是我们并没有指定实例的大小,因为vector是可以根据需求自动调整大小的,这一点跟数组不同。接下来我们调用函数push_back,该函数时在vector实例num的最后添加一个元素,因为一开始定义的时候为空,因此此时的num中只包含一个元素50。

之后我们再调用insert函数,该函数可以在指定位置插入元素。在insert参数中,我们分别调用了begin和end函数,这两个函数分别用来访问num实例的头部和尾部。begin()返回的是一个迭代器,如果容器不为空,则返回的迭代器指向容器的第一个元素;如果容器为空,则返回的迭代器指向容器尾部之后的位置。end()函数同样返回的是一个迭代器,该迭代器指向的是容器尾部之后的位置。当容器为空时,begin()函数和end()函数都指向同一个位置,当容器有一个元素的时候,begin()函数指向第一个元素的位置,end()函数则指向第一个元素之后的位置。调用insert函数时,如果不是在容器尾部插入元素,则需要将所插入位置以后的元素都向后移一位,然后再将需要插入的元素插入到当前位置。例如我们要在开头插入一个元素,则需要将容器现有的元素都向后移动一个位置,然后再将元素插入到第一个位置,因此vector在非尾部位置插入元素,其效率不高。在主函数中调用两次insert函数之后,此时的容器num中的元素有:10,50,20。

之后又调用了两个push_back函数,在容器尾部插入了两次数据。此时容器中的数据按顺序依次为:10,50,20,60,40。

之后调用size函数,返回容器的大小,因为此时容器中包含五个元素,因此返回值为5。接下来我们将容器中的元素一一打印出来,我们可以通过下标操作符访问容器中的元素,打印结果为:10,50,20,60,40。

接下来调用erase函数删除容器中的元素,删除位置是容器第一个元素,删除之后,该位置就会空出,此时后面的元素需要全部向前移动一个位置。此时容器中的元素按顺序一次为:50,20,60,40。

例2:

#include <iostream>
#include <deque>
using namespace std; int main()
{
deque< int > num;
num.push_back();
num.insert(num.begin(), );
num.insert(num.end(), );
num.push_back();
num.push_back();
cout<<num.size()<<endl;
for(int i=; i < num.size(); i++)
cout<<num[i]<<" ";
cout<<endl;
num.erase(num.begin());
cout<<num.size()<<endl;
for(int i=; i < num.size(); i++)
cout<<num[i]<<" ";
cout<<endl;
return ;
}

我们将例1中的vector换成deque,运行程序我们发现两个程序的运行结果完全相同。是不是vector和deque相同呢?其实不是的,vector说到底是个数组,在非尾部插入元素都需要移动其它元素,而deque则不同,它是一个可以操作数组头部和尾部的数组,因此在头部或尾部插入或删除数据,其处理效率都是一样的。当我们需要频繁在头部和尾部插入或删除数据,则deque优于vector。

例3:

#include <iostream>
#include <string>
#include <list>
using namespace std; int main()
{
list< string > str;
str.insert( str.begin(), "A" );
str.insert( str.begin(), "B" );
str.insert( str.end(), "C" );
str.insert( str.end(), "D" );
str.insert( str.begin(), "E" );
str.insert( str.begin(), "F" );
list< string >::iterator iter;
for(iter = str.begin(); iter != str.end(); iter++)
cout<< * iter <<endl;
str.reverse();
for(iter = str.begin(); iter != str.end(); iter++)
cout<< * iter <<endl;
return ;
}

在本例中我们定义了一个list容器string类型的实例str,之后我们先在容器中添加了6个string类型元素,为了遍历str容器,我们定义了一个迭代器iter。通常每定义一个容器,就会有一个与容器数据类型相关的迭代器,本例中定义了容器str,则它的对应的容器有:

list < string >::iterator
list< string >::const_iterator

如果我们不需要修改容器中的元素,仅仅只是进行访问的话,则可以定义为const_iterator。

为了从头到尾遍历容器,我们先将迭代器指向str.begin(),for循环的结束条件是str.end(),每次运行一遍循环体中的内容,迭代器自增一次,相当于指向下一个元素,我们之所以能够直接使用自增运算符,那是因为在容器的类中系统已经重载过了自增操作符。当我们需要获得当前迭代器所指的元素时,我们可以用取址操作符“*”来操作迭代器,“*iter”就为迭代器所指向的元素。在此程序中我们之所以没有按照vector和deque的方式,以下标进行访问容器中的元素,那是因为list并没有重载下标操作符,因而不能根据下标进行直接访问。

在主函数中我们调用了reverse函数,对容器中的元素进行翻转,然后再次打印容器中的元素。

list容器是一个双向链表,因此在容器中的任何位置插入元素,都不需要移动其它元素,因此执行效率是稳定的。

7.5 C++基本序列式容器的更多相关文章

  1. STL源码剖析读书笔记--第四章--序列式容器

    1.什么是序列式容器?什么是关联式容器? 书上给出的解释是,序列式容器中的元素是可序的(可理解为可以按序索引,不管这个索引是像数组一样的随机索引,还是像链表一样的顺序索引),但是元素值在索引顺序的方向 ...

  2. STL源码剖析之序列式容器

    最近由于找工作需要,准备深入学习一下STL源码,我看的是侯捷所著的<STL源码剖析>.之所以看这本书主要是由于我过去曾经接触过一些台湾人,我一直觉得台湾人非常不错(这里不涉及任何政治,仅限 ...

  3. STL序列式容器学习总结

    STL序列式容器学习总结 参考资料:<STL源码剖析> 参考网址: Vector: http://www.cnblogs.com/zhonghuasong/p/5975979.html L ...

  4. STL——序列式容器

    一.容器概述与分类 1. STL容器即是将运用最广的一些数据结构实现出来.常用的数据结构有array, list, tree, stack, queue, hash table, set, map…… ...

  5. STL学习笔记(序列式容器)

    Vector Vector是一个动态数组. 1.Vector的操作函数 构造.拷贝和析构 vector<Elem> c //产生一个空vector ,其中没有任何元素 vector< ...

  6. vector是序列式容器而set是关联式容器。set包含0个或多个不重复不排序的元素。

    1.vector是序列式容器而set是关联式容器.set包含0个或多个不重复不排序的元素.也就是说set能够保证它里面所有的元素都是不重复的.另外对set容器进行插入时可以指定插入位置或者不指定插入位 ...

  7. STL源码剖析——序列式容器#1 Vector

    在学完了Allocator.Iterator和Traits编程之后,我们终于可以进入STL的容器内部一探究竟了.STL的容器分为序列式容器和关联式容器,何为序列式容器呢?就是容器内的元素是可序的,但未 ...

  8. 数据结构-STL序列式容器总结

    根据序列在容器中的排列特性,将常见数据结构分为:序列式容器和关联式容器. 常见序列式容器有 1.array(build-in)c++內建 2.vector 3.heap(以算法方式呈现) 4.prio ...

  9. STL源码剖析:序列式容器

    前言 容器,置物之所也.就是存放数据的地方. array(数组).list(串行).tree(树).stack(堆栈).queue(队列).hash table(杂凑表).set(集合).map(映像 ...

随机推荐

  1. 雷林鹏分享:C# 循环

    C# 循环 有的时候,可能需要多次执行同一块代码.一般情况下,语句是顺序执行的:函数中的第一个语句先执行,接着是第二个语句,依此类推. 编程语言提供了允许更为复杂的执行路径的多种控制结构. 循环语句允 ...

  2. 20180831xlVBA_WorkbooksCosolidate

    Sub WorkbooksConsolidate() Rem 设置求和区域为 sheet名称/单元格区域;sheet名称/单元格区域 Const Setting As String = "S ...

  3. Webpack实现路由懒加载的三种方式

    原文指路:https://blog.csdn.net/qq_37540004/article/details/78727063 第一种: 引入方式(正常引入): const router = new ...

  4. 『TensorFlow』分布式训练_其一_逻辑梳理

    1,PS-worker架构 将模型维护和训练计算解耦合,将模型训练分为两个作业(job): 模型相关作业,模型参数存储.分发.汇总.更新,有由PS执行 训练相关作业,包含推理计算.梯度计算(正向/反向 ...

  5. 3月19 HTML静态网页的制作

    HTML :内容(Hyper Text Markup Language,超文本标记语言) <html>---开始标签 <head> 网页上的控制信息 <title> ...

  6. Beta阶段——第5篇 Scrum 冲刺博客

    Beta阶段--第5篇 Scrum 冲刺博客 标签:软件工程 一.站立式会议照片 二.每个人的工作 (有work item 的ID) 昨日已完成的工作 人员 工作 林羽晴 完成了邮箱发送功能的测试,测 ...

  7. android project

  8. Oracle 12c新特性之——TABLE ACCESS BY INDEX ROWID BATCHED

    Oracle12c开始,我们在获取SQL语句的执行计划时,也会经常看到"TABLE ACCESS BY INDEX ROWID BATCHED"操作,那么,这个操作到底是什么意思呢 ...

  9. PHP指针相关函数

    1.each each — 返回数组中当前的键/值对并将数组指针向前移动一步 $arr = array("one", "two", "three&qu ...

  10. JavaScript 上万条数据 导出Excel文件 页面卡死

    最近项目要js实现将数据导出excel文件,网上很多插件实现~~那个开心呀,谁知道后面数据量达到上万条时出问题:浏览器不仅卡死,导出的excel文件一直提示网络失败.... debug调试发现var  ...