Vector(容器)
vector(容器)就像数组一样,但比数组强大很多,下面介绍一下vector常用的几种方法:
一、对于vector自身的处理,包括赋初始值,复制等等;
vector<int> v1 ;
vector<int> v2( 5 , 10) ; // v2 中有5个元素,每个元素都是10
vector<int> v3( v2 ) // 将 v2 复制给 v3
vector<int> v4( v3.begin() , v3.end() ) // 同样是将 v3 复制给 v4 ;
int a[] = {1,2,3,4,5} ;
vector<int> v5( a , a + sizeof(a) / sizeof(int) ) // 将数组 a 中的元素复制给 v5 ;
二、vector::operator ;
vector<int> v1( 5 , 10 ) ;
vector<int> v2 ;
v2 = v1 ; // 相当于将 v1 复制给 v2 ;
三、vector 中的 begin 和 end 函数 ;
begin 和 end 函数返回的都是当前指针并不是容器中的数值;
存储当前返回指针的变量用:vector<int>::iterator iter ;
vector<int> v( 5 , 10 ) ;
*(v.begin()) // 输出第一个元素 ;
*(v.end() - 1) // 输出最后一个元素 ;
四、vector 中的 rbegin 和 rend 函数 ;
rbegin 和 rend 函数返回的同样是指针,不过和 begin、end 返回的不同,一个是从前往后返回,一个是从后往前返回;
存储当前返回指针的变量用: vector<int>::reverse_iterator iter ;
*(v.rbegin()) // 输出最后一个元素 ;
*(v.rend() - 1) // 输出第一个元素 ;
五、vector 中的 size、push_back、pop_back、inseart函数
vector<int> v1( 5 , 10 ) ;
v1.size() // 返回v1 的大小 ;
v1.push_back( 6 ) ; // 在v1后继续添加一个元素6 ;
v1.pop_pack() ; // 将v1 的最后一个元素删除掉 ;
insert 可以在vector对象的任意位置插入一个元素
v1.insert(v1.begin() , 10) ; // 在第一个元素的前面插入一个元素10 ;
v1.insert(v1.begin()+1 , 10) ; // 在第二个元素的前面插入一个元素10 ;
v1.insert(v1.begin() , 5 , 10) ; // 在第一个元素前面插入5个元素10 ;
v1.insert(v1.end() , 5) ; // 在最后插入一个元素 5 , 相当于v1.push_back(5) ;
v1.insert(v1.end() , 5 , 10) ; // 在最后插入5个元素10 ;
六、vector中的 resize 函数
resize函数主要用来重新定义容器的大小,如果比当前的大,可以自定义赋初值,也可以使用默认初值0 ;如果比当前的小,只取定义的部分;
vector<int> v1(10 , 10) ;
v1.resize(5) ; // 原来的十个元素,现在只剩下五个 ;
v1.resize(12,20) ; // 原来的十个元素现在变成了十二个,新增加的部分用20来赋值 ;
七、vector中的 at 函数
at 函数用来在容器相应的位置存储对象;
vector<int> v1(5 , 10) ;
v1.at[2] = 2 ; // 将第三个元素改为2,相当于v1[2] = 2 ;
八、vector中的 erase 函数
erase 函数用来删除容器中的数据元素 ;
vector<int> v1( 5 , 10) ;
v1.erase(v1.begin()) ; // 删除第一个元素 ;
v1.erase(v1.begin() , v1.begin() + 3) ; // 删除前三个元素 ;
对于vector这些好用的性质要比数组操作起来方便多了,以后要多多使用!
Vector(容器)的更多相关文章
- 把《c++ primer》读薄(3-2 标准库vector容器+迭代器初探)
督促读书,总结精华,提炼笔记,抛砖引玉,有不合适的地方,欢迎留言指正. 标准库vector类型初探,同一种类型的对象的集合(类似数组),是一个类模版而不是数据类型,学名容器,负责管理 和 存储的元素 ...
- C++ STL vector容器学习
STL(Standard Template Library)标准模板库是C++最重要的组成部分,它提供了一组表示容器.迭代器.函数对象和算法的模板.其中容器是存储类型相同的数据的结构(如vector, ...
- vector容器使用和assert断言关键字
C++里面的容器是个比较复杂的东西,我这篇只说vector容器怎么使用,详细的网搜. vector模板类其实是一个动态数组,跟自己用new关键字创建数组一样,只不过vector会自动帮我们用new和d ...
- C++杂谈(二)初识vector容器与迭代器
教科书中失踪的vector 很奇怪的一件事情,在当时学习C++的时候,老师并没有讲授容器的内容,当时参考的谭浩强老师的红皮C++也没有这个内容,不知为何.后来再学C++,发现容器是一个很重要的概念,在 ...
- vector容器的用法
转自一篇博客^-^: 1 基本操作 (1)头文件#include<vector>. (2)创建vector对象,vector<int> vec; (3)尾部插入数字:vec.p ...
- C++ Daily《2》----vector容器的resize 与 reserve的区别
C++ STL 库中 vector 容器的 resize 和 reserve 区别是什么? 1. resize 改变 size 大小,而 reserve 改变 capacity, 不改变size. 2 ...
- 跟我一起学STL(2)——vector容器详解
一.引言 在上一个专题中,我们介绍了STL中的六大组件,其中容器组件是大多数人经常使用的,因为STL容器是把运用最广的数据结构实现出来,所以我们写应用程序时运用的比较多.然而容器又可以序列式容器和关联 ...
- vector容器+iterator迭代器
关于vector容器的详细描述,可参考:http://www.jb51.net/article/41648.htm 关于iterator迭代器的描述,可参考http://www.cppblog.c ...
- 提高Vector容器的删除效率
vector容器是类似与一个线性数组,索引效率高,插入,删除的效率很低,需要遍历数据列表,一般情况下vector的删除操作由一下函数完成: iterator erase(iterator positi ...
- 标准模板库(STL)学习探究之vector容器
标准模板库(STL)学习探究之vector容器 C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...
随机推荐
- perl 升级到5.20版本
不建议先rm 先下载tar.gz ...然後手动安装..default 安装到/usr/local/目录下.. 然後修改/usr/bin/perl的symbolic link到/usr/local/b ...
- C语言入门(4)——常量、变量与赋值
对于基本数据类型量,按其取值是否可改变又分为常量和变量两种.在程序执行过程中,其值不发生改变的量称为常量,其值可变的量称为变量.它们可与数据类型结合起来分类. 常量 常量有字符常量(Character ...
- 利用KVO监视一个view的frame
首先,keyPath一定是frame,而不是frame.origin.x之类的路径,因为再点下去的话,就是访问结构体内部的值了,KVO是无法检测的,会报错找不到KeyPath. 代码如下: [_fun ...
- poj2186 Popular Cows --- 强连通
给一个有向图,问有多少结点是其它全部结点都能够到达的. 等价于,在一个有向无环图上,找出度为0 的结点.假设出度为0的结点仅仅有一个,那么这个就是答案.假设大于1个.则答案是0. 这题有环.所以先缩点 ...
- Codeforces Round #262 (Div. 2) B
题目: B. Little Dima and Equation time limit per test 1 second memory limit per test 256 megabytes inp ...
- mysql基础示例
创建数据库.创建表等: //php中按天创建表 $sql = "create database if not exists ".$db_name; $date_time_array ...
- 侯老师的话(Application Framework)
摘自http://blog.csdn.net/zlc19876/article/details/5355022 本篇文章主要介绍了"侯老师的话(Application Framework)& ...
- MD5和sha1加密算法
在很多电子商务和社区应用中,我们都要存放很多的客户的资料,其中包括了很多的隐私信息和客户不愿被别人看到的信息,当然好有客户执行各种操作的密码,此时就需要对客户的信息进行加密再存储,目前有两种比较好的加 ...
- [转]PB 基本语句 循环语句
PB 基本语句一.赋值语句赋值语句用于给变量.对象属性赋值,这是应用程序中使用最频繁的语句,其语法格式为:variablename = expression_r其中:⑴variablename是变量名 ...
- Java环境的配置
JAVA环境: 1.打开我的电脑--属性--高级--环境变量 2.将相应的JDK环境下载到本机,将路径保存到无中文路径中,并将路径复制下来. 3.在环境变量--系统变量,中新建 变量名:JAVA_HO ...