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(容器)的更多相关文章

  1. 把《c++ primer》读薄(3-2 标准库vector容器+迭代器初探)

    督促读书,总结精华,提炼笔记,抛砖引玉,有不合适的地方,欢迎留言指正. 标准库vector类型初探,同一种类型的对象的集合(类似数组),是一个类模版而不是数据类型,学名容器,负责管理 和 存储的元素 ...

  2. C++ STL vector容器学习

    STL(Standard Template Library)标准模板库是C++最重要的组成部分,它提供了一组表示容器.迭代器.函数对象和算法的模板.其中容器是存储类型相同的数据的结构(如vector, ...

  3. vector容器使用和assert断言关键字

    C++里面的容器是个比较复杂的东西,我这篇只说vector容器怎么使用,详细的网搜. vector模板类其实是一个动态数组,跟自己用new关键字创建数组一样,只不过vector会自动帮我们用new和d ...

  4. C++杂谈(二)初识vector容器与迭代器

    教科书中失踪的vector 很奇怪的一件事情,在当时学习C++的时候,老师并没有讲授容器的内容,当时参考的谭浩强老师的红皮C++也没有这个内容,不知为何.后来再学C++,发现容器是一个很重要的概念,在 ...

  5. vector容器的用法

    转自一篇博客^-^: 1 基本操作 (1)头文件#include<vector>. (2)创建vector对象,vector<int> vec; (3)尾部插入数字:vec.p ...

  6. C++ Daily《2》----vector容器的resize 与 reserve的区别

    C++ STL 库中 vector 容器的 resize 和 reserve 区别是什么? 1. resize 改变 size 大小,而 reserve 改变 capacity, 不改变size. 2 ...

  7. 跟我一起学STL(2)——vector容器详解

    一.引言 在上一个专题中,我们介绍了STL中的六大组件,其中容器组件是大多数人经常使用的,因为STL容器是把运用最广的数据结构实现出来,所以我们写应用程序时运用的比较多.然而容器又可以序列式容器和关联 ...

  8. vector容器+iterator迭代器

    关于vector容器的详细描述,可参考:http://www.jb51.net/article/41648.htm   关于iterator迭代器的描述,可参考http://www.cppblog.c ...

  9. 提高Vector容器的删除效率

    vector容器是类似与一个线性数组,索引效率高,插入,删除的效率很低,需要遍历数据列表,一般情况下vector的删除操作由一下函数完成: iterator erase(iterator positi ...

  10. 标准模板库(STL)学习探究之vector容器

    标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...

随机推荐

  1. poj1969---找规律

    题意:按照s型分别给数编号,给 #include <stdio.h> #include <stdlib.h> int main() { int n; while(scanf(& ...

  2. Emotional Mastery——英语学习小技巧之一

    How can we control or manage our emotion ,so that we feel better and feel stronger when we're learni ...

  3. 开源点评:Protocol Buffers介绍

    今天来介绍一下“Protocol Buffers”(下面简称protobuf)这个玩意儿.本来俺在构思“生产者/消费者模式 ”系列的下一个帖子:关于生产者和消费者之间的传输数据格式.因为里面扯到了pr ...

  4. asp.net MVC Razor 语法(1)

    Razor 不是编程语言.它是服务器端标记语言. 什么是 Razor ? Razor 是一种允许您向网页中嵌入基于服务器的代码(Visual Basic 和 C#)的标记语法. 当网页被写入浏览器时, ...

  5. 穿透的 div ( pointer-events )

    pointer-events 是一個滿有趣的 CSS3 屬性,雖然主要是針對 SVG ,但其中幾個屬性應用在 div 上也是頗有意思.顧名思義,這是一個針對滑鼠事件的屬性,預設值為 auto,若值為 ...

  6. BZOJ 1951: [Sdoi2010]古代猪文( 数论 )

    显然答案是G^∑C(d,N)(d|N).O(N^0.5)枚举N的约数.取模的数999911659是质数, 考虑欧拉定理a^phi(p)=1(mod p)(a与p互质), 那么a^t mod p = a ...

  7. hadoop笔记之hdfs

    1.HDFS设计基础与目标 1.HDFS设计基础与目标 (1)硬件错误是常态,因此需要冗余. (2)流式数据访问.即数据批量读取而非随机读写,Hadoop擅长做的是数据分析而不是事务处理. (3)大规 ...

  8. NETTY 编码器介绍

    1. 背景 1.1. 编解码技术 通常我们也习惯将编码(Encode)称为序列化(serialization),它将对象序列化为字节数组,用于网络传输.数据持久化或者其它用途. 反之,解码(Decod ...

  9. hdu 2295 Radar 重复覆盖+二分

    题目链接 给m个雷达, n个城市, 以及每个城市的坐标, m个雷达里只能使用k个, 在k个雷达包围所有城市的前提下, 求最小半径. 先求出每个雷达到所有城市的距离, 然后二分半径, 如果距离小于二分的 ...

  10. 走进C标准库(6)——"string.h"中函数的实现memchr

    我写的memchr: void *memchr(const void *buf, char ch, unsigned count){ unsigned ; while(*(buf++) != ch & ...