C++中vector用法总结

vector是一个能够存放任意类型的动态数组。

1.构造函数

vector v;创建一个空vector
vector v(int n);创建一个元素个数为n的vector,初始值为0
vector v(int n,const t& t);创建一个元素个数为n,且值均为t的vector
vector v(const vector&);复制构造函数
vector v(begin,end);复制[begin,end)区间内另一个数组的元素到vector中
int a[3]={1,2,3} vector v(a,a+3);
vector<vector> vv(10, vector(8)); //10行8列,全为0
以下假设包涵:

#include

vector v;

int a;

2.增删

v.push_back(a);向vector中加入a元素
v.emplace_back(a);C11中加入,快于push_back();
v.pop_back();删除vector中末位元素
iterator insert(iterator it,const T& x):向量中迭代器指向元素前增加一个元素x
iterator insert(iterator it,int n,const T& x):向量中迭代器指向元素前增加n个相同的元素x
iterator insert(iterator it,const_iterator first,const_iterator last):向量中迭代器指向元素前插入另一个相同类型向量的[first,last)间的数据
iterator erase(iterator it):删除向量中迭代器指向元素
iterator erase(iterator first,iterator last):删除向量中[first,last)中元素
void clear():清空向量中所有元素
int b[7]={1,2,3,4,5,6,7};
vector v(10,3); //3 3 3 3 3 3 3 3 3 3
v.insert(v.begin(),4); //4 3 3 3 3 3 3 3 3 3 3
v.insert(v.end(),2,4); //4 3 3 3 3 3 3 3 3 3 3 4 4
v.insert(v.begin()+2,b+3,b+5); //4 3 4 5 3 3 3 3 3 3 3 3 3 4 4
v.erase(v.begin()+1); //4 4 5 3 3 3 3 3 3 3 3 3 4 4
v.erase(v.begin(),v.begin()+2); //5 3 3 3 3 3 3 3 3 3 4 4
v.clear(); //NULL

3.长度

int size() const:返回vector中元素的个数
int capacity() const:返回当前vector所能容纳的最大元素值
int max_size() const:返回最大可允许的vector元素数量值
vector v(5000,3);
cout<<v.capacity()<<" “<<v.size()<<” “<<v.max_size()<<endl;
v.insert(v.begin(),4);
cout<<v.capacity()<<” “<<v.size()<<” "<<v.max_size()<<endl;

//5000 5000 1073741823
//10000 5001 1074731823

4.判断空否

bool empty() const;空真1,非空假0。

5.遍历

reference at(int pos):返回pos位置元素的引用
reference front():返回首元素的引用
reference back():返回尾元素的引用
reverse_iterator rbegin():反向迭代器,指向最后一个元素
reverse_iterator rend():反向迭代器,指向第一个元素之前的位置

6.其他

v.reserve(100);扩容
reverse(v.begin(),v.end());转置//reverse和reserve傻傻分不清楚
resize(int n);调整容器的长度大小,使其能容纳n个元素
sort(v.begin(),v.end());
copy(v.placeA,v.placeB,vv.placeC);此处copy数量与数组容量相关,使用需注意
lower_bound( )和upper_bound( )都是用二分查找在一个有序数组中查找。
v.front();
v.back();
nth_element(v.begin(),v.begin()+k,v.end());将第k小元素放到它该放的位置上(从0开始算),左边元素都小于等于它,右边元素都大于等于它,如找第五小元素:

lower_bound( begin,end,num):查找第一个大于或等于num的数字,找到返回地址,否则返回end。返回地址-起始地址=下标。

upper_bound( begin,end,num):查找第一个大于num的数字,找到返回地址,否则返回end。返回地址-起始地址=下标。

auto it = lower_bound(minnums.begin(), minnums.end(), v);
*it = v;

————————————————

原文链接:https://blog.csdn.net/wenmiao_/article/details/82315552

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值