vector容器

本文介绍了C++的vector容器,其底层数据结构为动态数组,并详细阐述了如何通过push_back、insert、pop_back和erase进行元素的增删操作。同时,提到了查询元素的方式,如数组下标和迭代器,并警告在连续插入或删除后需要注意迭代器的更新。还提及了vector的一些常用方法,如reserve、resize和swap。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

底层数据结构:动态开辟的数组,每次以原来空间大小的二倍进行扩容。

头文件:
#include < vector >

增加:
vec.push_back(20);//向容器末尾添加元素,时间复杂度O(1),可能导致容器扩容
vec.insert(it, 20);//在迭代器的位置插入元素,每次插入都会导致数据位置移动,时间复杂度O(n)

删除:
vec.pop_back();//末尾删除元素,时间复杂度O(1)
vec.erase(it);//删除迭代器指向的元素,时间复杂度O(n)

查询:
operator[] 数组下标的随机访问 例如vec[5];
iterator迭代器进行遍历;
find;
for_each;
注意:对容器进行连续的删除或插入操作(insert/erase),一定要更新迭代器,否则第一次操作完成后,迭代器就失效了
常用方法:
sizeof();
empty();
reserve(20); 接收一个整数
resize(20); 容器扩容时使用
swap ;两个容器进行元素交换

实例:

#include <iostream>
#include <vector>
using namespace std;

int main()
{
   
    vector<int> vec;
     vec.reserve(20);//给容器预留空间,只给容器底层开辟指定大小的空间 并不会添加元素,目的是减少频繁的扩容操作
    cout << vec.empty() << endl;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值