vector容器

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

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

头文件:
#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;
    cout << vec.size() << endl;
    for (int i = 0; i < 20; ++i)
    {
        vec.push_back(rand()%100+1);
    }
    int size = vec.size();
    for (int i = 0; i < size; ++i)
    {
        //使用vec的operator[]运算符重载
        cout << vec[i] << " ";
    }
    cout << endl;

    //删除容器内所有偶数
    auto it1 = vec.begin();
    while(it1 != vec.end())
    {
        if (*it1 % 2 == 0)
        {
            it1 = vec.erase(it1);
        }
        else
        {
            ++it1;
        }
    }
    //通过迭代去去访问容器内的元素
    auto it = vec.begin();
    for (; it != vec.end(); ++it)
    {
        cout << *it << " ";
    }
    cout << endl;
    //给容器所有奇数前面都加个-1的数
    for (it1 = vec.begin(); it1 != vec.end();++it1)
    {
        if (*it1 % 2 != 0)
        {
            it1 = vec.insert(it1, *it1 - 1);
            ++it1;
        }
    }
    for (it1 = vec.begin(); it1 != vec.end(); ++it1)
    {
        cout << *it1 << " ";
    }
    cout << endl;
}

运行结果:
在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值