c++ vector用法

c++ vector用法

1.头文件

#include<vector>

2.vector的创建

vector<int> a;

3.vector的初始化

vector<int> a(10);//初始化了其大小,但并没有初始化其值

vector<int> a(10,1);//初始化其大小,并将每个元素的初始值初始化为1

int b=2;
vector<int> a(b);//初始化了其大小,

vector<int> b(10,1);
vector<int> a(b);//用b向量来创建a向量,实现整体复制;
vector<int> a(b.begin();b.begin()+3);//定义了a中的值为b中的0到第2个元素

int b[7] = {1,2,3,4,5,6,7,8,9};
vector<int> a(b,b+7);//从数组中获得初始值

4.vector的一些方法

a.assign(b.begin(), b.begin()+3); //b为向量,将b的0~2个元素构成的向量赋给a

a.assign(4,2); //是a只含4个元素,且每个元素为2

a.back(); //返回a的最后一个元素

a.front(); //返回a的第一个元素

a[i]; //返回a的第i个元素,当且仅当a[i]存在2013-12-07

a.clear(); //清空a中的元素

a.empty(); //判断a是否为空,空则返回ture,不空则返回false

a.pop_back(); //删除a向量的最后一个元素

a.erase(a.begin()+1,a.begin()+3); //删除a中第1个(从第0个算起)到第2个元素,也就是说删除的元素从a.begin()+1算起(包括它)一直到a.begin()+3(不包括它)

a.push_back(5); //在a的最后一个向量后插入一个元素,其值为5

a.insert(a.begin()+1,5); //在a的第1个元素(从第0个算起)的位置插入数值5,如a为1,2,3,4,插入元素后为1,5,2,3,4

a.insert(a.begin()+1,3,5); //在a的第1个元素(从第0个算起)的位置插入3个数,其值都为5

a.insert(a.begin()+1,b+3,b+6); //b为数组,在a的第1个元素(从第0个算起)的位置插入b的第3个元素到第5个元素(不包括b+6),如b为1,2,3,4,5,9,8,插入元素后为1,4,5,9,2,3,4,5,9,8

a.size(); //返回a中元素的个数;

a.capacity(); //返回a在内存中总共可以容纳的元素个数

a.resize(10); //将a的现有元素个数调至10个,多则删,少则补,其值随机

a.resize(10,2); //将a的现有元素个数调至10个,多则删,少则补,其值为2

a.reserve(100); //将a的容量(capacity)扩充至100,也就是说现在测试a.capacity();的时候返回值是100.这种操作只有在需要给a添加大量数据的时候才显得有意义,因为这将避免内存多次容量扩充操作(当a的容量不足时电脑会自动扩容,当然这必然降低性能) 

a.swap(b); //b为向量,将a中的元素和b中的元素进行整体性交换

a==b; //b为向量,向量的比较操作还有!=,>=,<=,>,<

5.向vector数组中添加数据

运用push_back方法添加

for(int i = 0;i<a.size();i++){
	a.push_back[i];
}

*注意

使用vector时,添加元素不能直接用a[i] = i操作。

for(int i = 0;i<a.size();i++){
	a[i] = i;
}

这种方法只能修改已有数据的元素的数据,而不能添加。

6.遍历vector数组的方法

6.1使用循环对元素进行遍历

for(int i = 0;i<a.size();i++){
	cout<<a[i];
}

6.2使用迭代器进行遍历

for(vector<int>::iterator it = a.begin(); a!=a.end();it++){
	cout<<*it;
}

7.几种重要的算法

需要导入头文件

#include<algorithm>
sort(a.begin(),a.end());//对a中的元素 ( 包括a.begin()与a.end() )进行从小到大的排序
reverse(a.begin(),a.end());//将a中的元素进行倒置,不会进行排序,只会进行倒置,如1,2,3,4变为4,3,2,1
copy(a.begin(),a.end(),b.begin()+1)//将a中的元素从b中b.begin()+1元素的位置开始复制,会覆盖掉原有元素
find(a.begin(),a.end(),10)//在a中的元素(包括a.begin(),但是不包括a.end();)中查找元素值为10,若存在则返回其位置。
  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值