学过C++的人肯定会很熟悉STL标准模板库,STL其实就是封装了一系列的接口,供我们调用很多函数或者算法的实现不需要我们从头开始写,大大提高我们的编程效率。这篇博客在简单介绍STL的情况下,会详细的来介绍vector的使用。

   官方文档链接

  STL共有六大组件:

一: 容器(container): 是一种数据结构,如list,vector,deque,queue等,以模板类的方法提供,为了访问容器中的数据,可以使用由容器类提供的迭代器。

二、 迭代器(Iterator):提供了访问容器中对象的方法。

三、算法(Algorithm):用来操作容器中的数据的模板函数。

四、仿函数(Function object)。

五、迭代适配器(Adapter)。

六、控件适配器(allocator)。

  这篇博客我们先来谈谈vector。vector对应的数据结构为数组,而且是动态数组,也就是说我们不必关心该数组事先定义的容量是多少,它的大小会动态增长。与数组类似的是,我们可以在末尾进行元素的添加和删除,也可以进行元素值的随机访问和修改。

  首先要引入头文件 #include <vector>。具体使用如下:

(1)vector的创建:

vector<int> vec1; // 创建一个空的vector
vector<int> vec2(vec1); // 创建一个vector vec2,并用vec1去初始化vec2
vector<int> vec3(); // 创建一个含有n个数据的vector
vector<int> vec4(,); // 创建含有10个数据的vector,并全部初始化为0

构造函数进行了重载,可以用多种方式创建vector。

(2)push_back(),pop_back()添加删除元素

// 在vector尾部添加元素
vec1.push_back();
vec1.push_back();
vec1.push_back();
vec1.push_back();
vec1.push_back();
PrintVector(vec1); // 在vector尾部删除元素
vec1.pop_back();
PrintVector(vec1); // 在vector头部添加元素,无法完成,因为vector的数据结构为数组,无法在头部插入元素,否则需要整个数组前移; // 在vector头部删除元素,无法完成,理由同上。

可以使用push_back()不断的在vector尾部添加元素,使用pop_back删除尾部元素。操作非常的方便,比我们直接用数组结构方便多了。

(3)[],at(),取某位置的元素值

  1. // 取vector中某位置的元素值
  2. cout << "在1位置的元素值为:" << vec1.at(1) << endl;
  3. cout << "在1位置的元素值为:" << vec1[1] << endl;

  因为vector的数据结构就是一个数组,所以可以进行随机访问。

(4)begin(),end(),指向头元素、尾元素的指针

void PrintVector(vector<int> ve)
{
cout << "Vector中的数据为:";
vector<int>::iterator veIterator;
for (veIterator = ve.begin(); veIterator < ve.end(); veIterator++)
{
cout << *veIterator << " ";
}
cout << endl;
}

(5)back(),front(),访问头部元素和尾部元素

// 返回尾部数据的引用
cout << "尾部数据的值为:" << vec1.back() << endl;
// 返回头部数据的引用
cout << "头部数据的值为:" << vec1.front() << endl;

(6)max_size(),vector的最大容纳量;size():vector当前的元素个数。

cout << "vector中的最大容量为:" << vec1.max_size() << endl;
cout << "vector中的元素个数为:" << vec1.size() << endl;

(7)empty(),判断vector是否为空

cout << "vector是否为空:" << vec1.empty() << endl;  

如果为空,返回1.否则返回0。

(8)swap():交换两个vector中的值。

(9)sort():对vector升序排序;reverse():对vector降序排序。

(10)erase():删除某个元素

// 删除数组的某个元素
// 为什么要使用iterator来进行定位,因为数组如果要删除一个元素或者插入一个元素,会导致其他元素移动,所以不能直接进行删除
vector<int>::iterator vItera = vec1.begin();
vItera = vItera + ;
vec1.erase(vItera);
PrintVector(vec1);

(11)clear():清除所有元素

// 清除所有数据
vec1.clear();
PrintVector(vec1);
cout << "vector是否为空:" << vec1.empty() << endl;

参考文章:

http://www.cplusplus.com/reference/queue/queue/

http://mropengate.blogspot.com/2015/07/cc-vector-stl.html

http://blog.csdn.net/chenyufeng1991/article/details/52269300

http://blog.csdn.net/wallwind/article/details/6858634

C++ STL 初探的更多相关文章

  1. C++模板之Vector与STL初探

    STL源码初步接触 STL = Standard Template Library,直译过来是:标准模板库,是惠普实验室开发的一系列软件的统称.从根本上说,STL是一些"容器"的集 ...

  2. STL初探

    关于STL的一些东西 感言: 学C++不学STL函数库的人可能都是... 有点问题 头文件<algorithm>的一些东西 sort,快排: 这是个初学者必需掌握的东西,及其好用,因为方( ...

  3. c++ STL容器初探

    什么是容器 首先,我们必须理解一下什么是容器,在C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器.很简单,容器就是保存其它对象的对象 ...

  4. 初探STL之算法

    算法 STL算法部分主要由头文件<algorithm>,<numeric>,<functional>组成.要使用 STL中的算法函数必须包括头文件<algor ...

  5. 『嗨威说』算法设计与分析 - STL中Sort函数的实现原理初探

    本文索引目录: 一.对Sort算法实现的个人阅读体会 二.Sort算法使用的三个排序算法的优点介绍 2.1 插入排序的优缺点 2.2 堆排序的优缺点 2.3 快速排序的优缺点 2.4 新的结合排序—— ...

  6. nginx平台初探(100%)

    http://tengine.taobao.org/book/chapter_02.html 初探nginx架构(100%)¶ 众所周知,nginx性能高,而nginx的高性能与其架构是分不开的.那么 ...

  7. nginx -- nginx平台初探(100%)

    初探nginx架构(100%) 众所周知,nginx性能高,而nginx的高性能与其架构是分不开的.那么nginx究竟是怎么样的呢?这一节我们先来初识一下nginx框架吧. nginx在启动后,在un ...

  8. A*寻路初探(转载)

    启发式搜索:启发式搜索就是在状态空间中的搜索对每一个搜索的位置进行评估,得到最好的位置,再从这个位置进行搜索直到目标.这样可以省略大量无畏的搜索路径,提到了效率.在启发式搜索中,对位置的估价是十分重要 ...

  9. stl::iterator汇总

    STL——iterator 一.概述Iterator(迭代器)模式又称Cursor(游标)模式, 根据STL中的分类,iterator包括:Input Iterator:只能单步向前迭代元素,不允许修 ...

随机推荐

  1. java获取变量的类型

    对于简单类型变量,是无法直接获得变量类型的://要想获取,必须自定义函数进行返回 对于包装类型变量,是可以直接获得的,变量名称.getClass().getName(); java中获取变量的类型可以 ...

  2. ESRI.ArcGIS.AnalysisTools.Erase 结果是空?

    用ESRI.ArcGIS.AnalysisTools.Erase擦除,结果总是空的. 这几天一直纠结一个问题,就是在AE下使用ESRI.ArcGIS.AnalysisTools中的工具(例如:泰森多边 ...

  3. Linux 部署 tomcat 常用命令

    1.  文件夹重命名 mv somedir somedir1 2. 授权所有子目录 chmod -R 777 somedir 3.授权单个目录 chmod 777 somedir 4.实时打印控制台日 ...

  4. Codeforces777A Shell Game 2017-05-04 17:11 59人阅读 评论(0) 收藏

    A. Shell Game time limit per test 0.5 seconds memory limit per test 256 megabytes input standard inp ...

  5. hdu 5023 线段树+状压

    http://acm.hdu.edu.cn/showproblem.php?pid=5023 在片段上着色,有两种操作,如下: 第一种:P a b c 把 a 片段至 b 片段的颜色都变为 c . 第 ...

  6. 19、Docker Compose

      编排(Orchestration)功能是复杂系统实现灵活可操作性的关键.特别是docker应用场景中,编排意味着用户可以灵活地对各种容器资源实现定义和管理.   在我们部署多容器的应用时: 要从D ...

  7. Spine输出资源一键入Unity3D工具代码

    之前预研过2D骨骼动画编辑工具SPINE,感觉其比cocosStudio及Unity3D自带的骨骼动画编辑器(原生Sprite Tree或Uni2D)要更适合有3DSMax习惯的美术,即Spine更容 ...

  8. H2Database聚合函数

    聚合函数(Aggregate Functions) AVG  BOOL_AND  BOOL_OR  COUNT  GROUP_CONCAT MAX  MIN  SUM  SELECTIVITY  ST ...

  9. android应用搬家的实现

    android手机上的应用搬家功能,具体的介绍和原理参考: 系统目录及应用搬家的研究 应用搬家的实现 这里主要是作为一个补充,因为上面两篇文章虽然讲的挺好的,但是给出的例子不能直接运行,还是需要一些准 ...

  10. ASP.Net C#---Excel导入导入后台方法

    https://www.cnblogs.com/chendaye/p/10693983.html  这里写了Excel的导入导入方法, 后台我用的是MVC 以及 C#语句用来在后台做接受和输出数据 / ...