vector向量容器不但可以像数组一样对元素进行随机访问,还能在尾部插入元素,是一种简单高效的容器,可以代替数组。

vector具有内存自动管理的功能,对于元素的插入和删除,可以动态的调整所占内存。

对于vector容器的容量定义,可以事先定义一个固定大小,然后可以随时调整其大小;也可以事先不定义,随时使用push_back()方法从尾部扩张元素,也可以使用insert()在某个元素位置前面插入新元素。

vector容器有两个重要的方法,begin()和end()。begin()返回的是首元素位置的迭代器,end()返回的是最后一个元素的下一个元素位置的迭代器。

创建vector对象


创建vector对象的时候,可以不带参数,带一个参数,带两个参数:

(1)不指定容器的元素的个数(不带参数)
vector<int> v;

(2)指定容器的大小(带一个参数,表示容器的大小)

vector<double> v(10);

(3)创建一个具有n个元素的向量容器对象,每个元素具有指定的初值(带两个参数,分别表示容器的大小和每个元素的初值)

vector<int> v(10,0);

尾部元素扩张


通常使用push_back()对vector容器在尾部追加新元素。尾部追加元素,vector容器会自动分配新内存空间。

#include<vector>
using namespace std;
int main()
{
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
return 0;
}

上面的代码表示:将1,2,3三个元素从尾部添加到v容器中,现在容器的长度为3,三个元素分别是1,2,3


下表方式访问vector元素


可以像数组一样使用下标访问vector中的元素

#include<vector>
#include<iostream>
using namespace std;
int main()
{
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
cout<<v[0]<<endl;
v[1] = 10;
cout<<v[1]<<endl;
cout<<v[2]<<endl;
return 0;
}

程序输出:1 10 3


使用迭代器访问vector元素


常使用迭代器配合循环语句对vector对象进行遍历访问,迭代器的类型一定要与它要遍历的vector对象的元素类型一致。

#include<vector>
#include<iostream>
using namespace std;
int main()
{
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3); vector<int>::iterator it;
for(it=v.begin();it<v.end();it++)
{
cout<<*it<<endl;
}
return 0;
}

元素的插入


insert()方法可以在vector对象的任意位置前插入一个新的元素,同时,vector自动扩张一个元素空间,插入位置后的所有元素依次向后挪动一个位置。
要注意的是:inert()方法要求插入的位置是元素的迭代器的位置,而不是元素的下标。
insert(iterator,value)函数有两个参数,第一个是迭代器的位置,第二个是插入的数据的值。

#include<vector>
#include<iostream>
using namespace std;
int main()
{
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3); vector<int>::iterator it=v.begin();
v.insert(v.begin(),8);
v.insert(v.begin()+2,9);
v.insert(v.end(),10); for(it=v.begin();it<v.end();it++)
{
cout<<*it<<endl;
}
return 0;
}

输出结果是:8 1 9 2 3 10


向量的大小和元素的删除


erase()方法可以删除vector中迭代器所致的一个元素或者一段区间中的所有元素,如果带有一个参数,则删除对应迭代器位置的元素,如果对应的是两个参数,则删除的是第一个迭代器到第二个迭代器之间(包括第一个迭代器位置,不包括第二个迭代器位置)的元素,删除元素之后,后面的元素会提到前面去,将其覆盖。

clear()方法则一次性删除了vector中的所有的元素。

size()方法可以返回向量的大小,即元素的个数。

empty()方法可以返回向量是否为空(空则返回真,非空返回假)

#include<vector>
#include<iostream>
using namespace std;
int main()
{
vector<int> v;
for(int i=0;i<10;i++)
{
v.push_back(i);
}
cout<<"size:"<<v.size()<<endl; vector<int>::iterator it=v.begin();
v.erase(it+1); //删除v[1]
v.erase(it+4,it+7); //删除v[4]~v[5](!!注意此时的数组已经动态调整了)
for(it=v.begin();it<v.end();it++)
{
cout<<*it<<" ";
}
cout<<"\nempty:"<<v.empty()<<endl; v.clear(); cout<<"empty:"<<v.empty()<<endl;
return 0;
}

程序输出:

size:10

0 2 3 4 8 9

empty:0

empty:1

使用reverse反向排列算法

reverse反向排列算法,需要引入头文件algorithm。

#include<vector>
#include<algorithm>
#include<iostream>
using namespace std;
int main()
{
vector<int> v;
for(int i=0;i<10;i++)
{
v.push_back(i);
} vector<int>::iterator it=v.begin(); for(it=v.begin();it<v.end();it++)
{
cout<<*it<<" ";
}
cout<<endl; reverse(v.begin(),v.end()); for(it=v.begin();it<v.end();it++)
{
cout<<*it<<" ";
}
return 0;
}

输出结果:

0 1 2 3 4 5 6 7 8 9

9 8 7 6 5 4 3 2 1 0

使用sort算法对向量元素排序


使用sort算法对向量排序,也需要引入头文件algorithm。
sort算法要求使用随机访问迭代器进行排序,在默认情况下,对向量元素进行升序排列(当然可以认为进行改变)。

#include<algorithm>
#include<vector>
#include<iostream>
using namespace std;
bool Comp(const double &a,const double &b)
{
return a>b;
}
int main()
{
vector<double> v;
for(double i=2.0;i>1;i=i-0.1)
{
v.push_back(i);
}
sort(v.begin(),v.end()); vector<double>::iterator it=v.begin(); for(it=v.begin();it<v.end();it++)
{
cout<<*it<<" ";
} cout<<endl;
sort(v.begin(),v.end(),Comp); for(it=v.begin();it<v.end();it++)
{
cout<<*it<<" ";
} return 0;
}

输出结果:
1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2

2 1.9 1.8 1.7 1.6 1.5 1.4 1.3 1.2 1.1


vector向量容器的更多相关文章

  1. 学习笔记之vector向量容器

    今天复习到vector向量容器,里面包括vector向量容器的一些优点以及具体的使用方法及代码,分享给大家. Vector向量容器不但能够像数组一样对元素进行随机访问,还可以在尾部插入元素,是一种简单 ...

  2. vector向量容器(常用的使用方法总结)

    关于STL中vector容器的学习,编译运行后边看代码,边看执行结果效果更佳,还是想说看别人的代码一百遍,不如自己动手写一遍. vector向量容器不但能像数组一样对元素进行随机访问,还能随时在尾部插 ...

  3. 标准模板库使用参考——vector向量容器

    C++的STL从广义上讲分为algorithm(算法),container(容器)和iterator(迭代器)三类,包含了诸多在计算机科学领域里所常用的基本数据结构和基本算法. 在C++标准库中,ST ...

  4. vector向量容器元素排序与查找

    1.利用标准库函数sort()对vector进行排序 参考源码: #include <algorithm> #include <vector> vector<int> ...

  5. C++STL之vector向量容器

    vector向量容器   vector向量容器不但能向数组一样对元素进行随机访问, 还能在尾部插入元素 vector具有内存自动管理的功能, 对于元素的插入和删除, 可动态调整所占的内存空间 vect ...

  6. 利用copy函数简单快速输出/保存vector向量容器中的数据

    如果要输出vector中的数据我们可以通过循环语句输出,更加简便的方法是利用copy函数直接输出,例子: #include "stdafx.h" #include <iost ...

  7. vector 向量容器用法祥解

    vector(向量): C++中的一种数据结构,确切的说是一个类.它相当于一个动态的数组,当程序员无法知道自己需要的数组的规模多大时,用其来解决问题可以达到最大节约空间的目的. 用法:         ...

  8. C++ STL vector(向量容器)的使用(附完整程序代码)

    一.简单介绍 Vectors 包括着一系列连续存储的元素,其行为和数组类似. 訪问Vector中的随意元素或从末尾加入元素都能够在O(1)内完毕,而查找特定值的元素所处的位置或是在Vector中插入元 ...

  9. vector向量容器的一些基本操作

    #include <vector> #include <iostream> using namespace std; void print(vector<int>& ...

随机推荐

  1. poj 3517

    题目链接  http://poj.org/problem?id=3517 题意        约瑟夫环  要求最后删掉的那个人是谁: 方法        理解递推公式就行了  考虑这样一组数据  k ...

  2. HihoCoder 1121 二分图一•二分图判定

    二分图一•二分图判定 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 大家好,我是小Hi和小Ho的小伙伴Nettle,从这个星期开始由我来完成我们的Weekly. 新年回 ...

  3. python3 selenium 安装以及验证

    1. 相关链接 官方网站:http://www.seleniumhq.org GitHub:https://github.com/SeleniumHQ/selenium/tree/master/py ...

  4. 使用PHP判断是否为微信、支付宝等移动设备访问代码

    在开发过程中经常遇到根据不同的设备显示不同的数据或者在页面样式上做不同的布局,另外在做支付接口的时候也可能会判断当前是什么设备访问,例如判断如果是微信内置浏览器访问则只启用微信支付功能,如果是支付宝内 ...

  5. 致Oracle DBA 的一封信 (网上流传)

    1. 数据库的可用度,DBA 说了“不算”   --物化视图,加快查询速度 某些时候数据库的可用性,并不由DBA所设定.因为即使DBA对数据库有绝对掌控权,但用户可能从自己的工作和应用角度,与DBA的 ...

  6. 提升Apache网站访问速度的优化方法

    Apache是世界使用排名第一的Web服务器软件.它可以运行在几乎所有广泛使用的计算机平台上,由于其跨平台和安全性被广泛使用,是最流行的Web服务器端软件之一. 在Apache服务器上怎样优化才能提高 ...

  7. jquery中ajax异步调用接口

    之前写过一个原始的.无封装的页面,没有引入任何外部js,直接实例化Ajax的XmlRequest对象去异步调用接口,参见Ajax异步调用http接口后刷新页面,可对比一下. 现在我们用jquery包装 ...

  8. 【转】CentOs中Apache开启rewrite模块详解

    rewrite是apache环境的一个伪静态功能了,如果我们没有没让Apache开启rewrite功能,网站上所有的rewrite规则都不可使用. centos的配置文件放在: /etc/httpd/ ...

  9. HTTP重要概念

    connection连接 一个传输层的实际环流,它是建立在两个相互通讯的应用程序之间. 在http1.1,request和reponse头中都有可能出现一个connection的头,此header的含 ...

  10. (转)WebApi 上传文件

    本文转载自:http://www.cnblogs.com/zj1111184556/p/3494502.html public class FileUploadController : ApiCont ...