vector的定义

vector是C++标准库里最常用的容器,它之所以被称为容器,是因为它可以存放多个对象,所有在用一个容器中的对象都应该具有相同的类型。

vector也是一个类模板,这也是它能存放多种类型元素的原因。关于类模板的知识,请参考我的另一篇文章:http://blog.csdn.net/larry233/article/details/50985945

初始化vector

  • vectorv1; // vector that holds objects of type T.Default constructor v1 is empty
  • vectorv2(v1); //v2 is a copy of v1
  • vectorv3(n,i);//v3 has n elements with value i
  • vectorv4(n); //v4 has n copies of a value-initialized object

示例如下:

vector<int>ivec1;
vector<int>ivec2(10); //该容器含10个元素,被默认初始化为0
vector<int>ivec3(10,1); //该容器里的10个元素均为1
vector<string>ivec4(10,"hi");//该容器里的10个元素均为“hi”

vector的操作

  • v.empty()//Returns true if v is empty,otherwise returns false
  • v.size()//Returns numbers of elements in v
  • v.push_back(t)//Adds element with elements in v
  • v[n]//Returns element at position n in v
  • v1 == v2//Returns true if v1 equals to v2

向容器中增加元素

示例如下:

string word;
vector<string>text;
while(cin>>word){
text.push_back(word);
} int i;
vector<int>ivec;
while(cin>>i){
ivec.push_back(i);
}

用数组下标访问vector中的元素

示例如下:

for(vector<int>::size_type ix = 0; ix != ivec.size(); ++ix)
cout<<ivec[ix]<" ";

迭代器

尽管我们可以使用数组下标来访问vector中的元素,但是标准函数库也提供了另一种访问、处理元素的方式,那就是迭代器(iterator)。迭代器使得编写与容器类型无关的泛型算法成为可能。

vector的迭代器的声明

vector<int>::iterator iter;

使用迭代器的示例如下:

for(vector<int>::iterator iter = ivec.begin(); iter != ivec.end(); ++iter)
*iter = 0; //set element tp which iter refers to 0

const_iterator

如果我们不想改变迭代器指向的容器里的元素的值,我们可以使用const_iterator
示例如下:

for(vector<int>::const_iterator iter = ivec.begin(); iter != ivec.end(); ++iter)
cout<<*iter<<endl; //only print each value in ivec

使用const_iterator后,任何试图改变容器内的值的操作都是错误的:

for(vector<int>::const_iterator iter = ivec.begin(); iter != ivec.end(); ++iter)
*iter = 0; //error,*iter is const

const_iterator很容易和const iterator(const类型的iterator)搞混掉。我们可以这么理解:

const_iterator 类似于指向const类型变量的指针,而const类型的iterator类似于const pointer,即该iterator本身是const类型的。即:

//an iterator that can't write elements
vector<int>::const_iterator //an iterator whose value cann't change
const vector<int>::iterator

const iterator的示例如下:

vector<int>num(10);
const vector<int>::iterator cit = num.begin();
*cit = 1; //ok,cit can change its underlying element
++cit; //error,can't change the value of cit

由于const_iterator只能读取数据,因此它既能被用于const类型的vector,也能被用于non-const类型的vector。而const类型的iterator就显得”useless”了,因为一旦它被初始化,它就只能指向该元素,而不能指向其他元素。

const vector<int>nine(10,9);//cann't change elements in nines
//error:cit2 could change the element it refers to but nines is const
const vector<int>::iterator cit2 = nine.begin(); //ok:it cann't change an element value,so it can be used with a const vector<int>
vector<int>const_iterator it = nine.begin();
*it = 10;//error:*it is const
++it;//ok:it isn't const so we can change its value

iterator的算数运算

  • 迭代器只能与整数相加减,不能与迭代器相加,只能相减。比较属于两个不同容器对象的迭代器属于未定义的行为。如:

    iter + n

iter - n

iter1- iter2

相减运算不常见,不再赘述。

  • 更为实用的应用是直接对迭代器进行算数运算以改变它所指向的元素,如:
vector<int>::iterator mid = ivec.begin() + ivec.size() / 2;
//equals to:
vector<int>::iterator mid = (ivec.begin() + ivec.end()) / 2;

//写完这篇我就去好好复习,讲真。

Library vector Type的更多相关文章

  1. [Cpp primer] Library vector Type

    #include<vector> using std::vector; //Vector is a container. //It has a collection of same typ ...

  2. Library string Type

    The string type supports variable-length character strings.The library takes cares of managing memor ...

  3. [Cpp primer] Library string Type

    In order to use string type, we need to include the following code #include<string> using std: ...

  4. Library string type(2)——关于String的操作

    关于string的定义,请参阅博文http://blog.csdn.net/larry233/article/details/51483827 string的操作 s.empty() //Return ...

  5. qt+opencv LNK4272:library machine type 'x64' conflicts with target mathine type 'x86'

    运行时报错如上图所示,原因是你使用的opencv库是64位的,qt里面使用的编译器MSVC是32位的,解决方法如下: 将构建套件修改位64bit:

  6. C++primer学习笔记(一)——Chapter 3

    3.1 Namespace using Declarations 1.因为C++里有名字空间的定义,例如我们使用cin的时候必须写成std::cin,如果就用一次还是可以接受的,但是如果一直都这样,那 ...

  7. nomasp 博客导读:Android、UWP、Algorithm、Lisp(找工作中……

    Profile Introduction to Blog 您能看到这篇博客导读是我的荣幸.本博客会持续更新.感谢您的支持.欢迎您的关注与留言.博客有多个专栏,各自是关于 Android应用开发 .Wi ...

  8. C++学习书籍推荐《C++ Primer 第五版 (英文)》下载

    百度云及其他网盘下载地址:点我 编辑推荐 <C++ Primer(英文版)(第5版)>是全球最畅销的C++图书.这本久负盛名的C++经典教程,时隔八年之久,终迎来的重大升级.除令全球无数程 ...

  9. DLL中传递STL参数,vector对象作为dll参数传递等问题(转)

    STL跨平台调用会出现很多异常,你可以试试. STL使用模板生成,当我们使用模板的时候,每一个EXE,和DLL都在编译器产生了自己的代码,导致模板所使用的静态成员不同步,所以出现数据传递的各种问题,下 ...

随机推荐

  1. ZOJ-3720 Magnet Darts 计算几何,概率

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3720 题意:在一个矩形区域投掷飞镖,每个整点有磁性,每个点的磁性 ...

  2. php升级到5.4

    这里使用 Webtatic EL6的YUM源来安装php5.4,我们首页安装Webtatic EL6 YUM源 rpm -Uvh http://repo.webtatic.com/yum/el6/la ...

  3. [五]JFreeChart实践四之直线图

    重点: 1.时间序列集合作为dataset,一个时间序列为一条折线 2.时间序列可以是月:年,小时:天 3.准备好时间序列要放入时间序列集合中 4.将时间序列集合作为dataset传入ChartFac ...

  4. 1、IIS常见的的问难及解决方法

    配置IIS 7.5 出现的问题及解决办法: 1.问题:  CS0016: 未能写入输出文件“c:\Windows\Microsoft.NET\Framework64\v4.0.30319\Tempor ...

  5. Linux为Tomecat指定JDK

    在搭建Jenkin+Sonar集成时,由于系统环境配置了jdk1.7,但是jenkins在安装sonar的插件时,需要jdk1.8.,所以需要在Tomcat指定jdk1.8. (1)暂停Tomcat ...

  6. XML 语法规则

    转摘自:http://www.w3school.com.cn/xml/xml_elements.asp XML 语法规则 XML 文档包含 XML 元素. XML 的语法规则很简单,且很有逻辑.这些规 ...

  7. C++里面方便的打印日志到文件

    ofstream write; //write只是个名字 你可以定义为任何其他的名字 write.open("D:\prj\Robot\dev\face\facerecog\facereco ...

  8. 超详细单机版搭建hadoop环境图文解析

    前言: 年前,在老大的号召下,我们纠集了一帮人搞起了hadoop,并为其取了个响亮的口号“云在手,跟我走”.大家几乎从零开始,中途不知遇到多少问题,但终 于在回家之前搭起了一个拥有12台服务器的集群, ...

  9. PHP扩展开发01:第一个扩展【转】

    我们先假设业务场景,是需要有这么一个扩展,提供一个叫ccvita_string的函数,他的主要作用是返回一段字符.(这个业务场景实在太假,大家就这么看看吧)对应的PHP代码可能是这样: functio ...

  10. xargs i I{} 参数说明

    find . -type f | xargs -I{} md5sum {} find . -type f -name "*.txt" | xargs -i cp {} /tmp/k ...