C++ STL学习之vector

C++ STL学习之vector

vector:变长数组(不固定大小的数组),类比于栈

ps:

​ 使用前要包含头文件 以及

​ #include:algorithm意为"算法",是C++的标准模版库(STL)中最重要的头文件之一,提供了大量基于迭代器的非成员模版函数。

函数的调用: vector.对应函数名

​ size()//返回元素个数

​ empty()//返回是否为空;

​ clear()//清空元素,不清空内存
​ front()//返回第一个元素的值

​ back()//返回最后一个元素的值
​ push_back(x)//压入一个数x

​ pop_back()//弹出最后一个数
​ begin()

​ end()

​ at()//取出下标

	c_str()//执行

	erase()//根据迭代器的位置,删除元素;erase(myvector.begin() + 3)

​ fill//填充

​ find

​ find_if

​ find_if_not

​ insert()插入元素;insert(myvector.begin() + 3, 998);//在第4个位置插入

​ sort()由小到大排序,用法见下文

​ swap()//交换两个vector

Iterators(迭代器)

​ 迭代器可被用来访问一个容器类的所包函的全部元素,其行为像一个指针。举一个例子,你可用一个迭代器来实现对vector容器中所含元素的遍历。

​ //正向迭代器iterator,begin()返回一个迭代器,它指向容器c的第一个元素,end()返回一个迭代器,它指向容器c的最后一个元素的下一个位置

​ //反向迭代器reverse_iterator,rbegin()返回一个逆序迭代器,它指向容器c的最后一个元素,rend()返回一个逆序迭代器,它指向容器c的第一个元素前面的位置

vector<int>v;//相当于定义一个int类型的变长数组v
//vector:变量类型,相当于string int double
//<int>传入参数的类型,可以是float,double,string,int,Node...
//v是变量名
v.push_back(4);//压入一个值4
v.push_back(2);
v.push_back(8);

vector<int>::iterator it;//定义一个类型为vector<int>的迭代器
    for(it =v1.begin();it l=vl.end();it++)
     cout<< *it <<endl;// * 代表取这个it对应的元素

[]的使用和数组一样

v[0] = 1000;
cout <<v[0]<<endl;
是可以这样使用的,但是必须是先开辟了空间才能这样赋值,只定义了vector v就这样赋值时错误的!
vector的初始化
vector<int>abc(10);//初始化了10个默认值为0的元素
sort(v.begin(),v.end());//由小到大排序

清空vector的内存

/*C++中vector的clear()只是清空vector,并不会清空开的内存。用一种方法可以清空vector的内存。先定义一个空的vectorx,然后用需要清空的vector和x交换,因为x是局部变量,所以会被系统回收内存(注意大括号一定不能去掉)。*/
vector<int> v;
{
    vector<int>x;
    V. swap(x);
}

实用案例

//一、收缩内存
vector<int>v;
for(int i =0;i < 100000;i++)
{
    v.push_back(i);
}
//此时v的大小是100000,v的容量是138255,因为vector容器会自动多开辟一些空间给你
v.resize(3);
//此时v的大小是3,v的容量是138255,造成了内存浪费
vector<int>(v).swap(v);
//这样就可以把v的多余内存释放掉,原理是利用拷贝构造初始匿名对象
//二、巧用reverse预留空间
如果要开辟大量空间那么系统就要不断地开辟新空间然后再进行存储转移,
直接调用reserve(int类型要开辟空间的大小)就可以避免
//逆序遍历可以直接调用反向迭代器
for(vector<int>::reverse_iterator it = v.rbegin();it!=v.rend();it++)
{
    cout<<*it<
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hgchshs

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值