C++ vector 容器

C++ vector 容器

概述

C++的vector是一种非常强大的容器,它提供了动态数组的功能,可以自动调整大小以适应数据的增加或减少。vector是C++标准模板库(STL)中的一部分,它支持对元素的随机访问,并且在插入和删除操作时提供了高效的性能。

vector 的基本特性

动态数组

vector内部使用动态数组来存储元素。这意味着它可以在运行时增加或减少其容量,从而无需手动管理内存。

随机访问

vector支持对元素的随机访问,这意味着你可以使用索引来快速访问任何位置的元素。

大小可变

vector的大小是可变的,你可以使用push_back()pop_back()来添加和删除元素。

性能

vector在插入和删除元素时通常比其他容器(如list)要快,因为它支持连续内存。

vector 的使用

创建 vector

cpp 复制代码
#include <vector>

int main() {
    std::vector<int> myVector;
    return 0;
}

添加元素

cpp 复制代码
#include <vector>

int main() {
    std::vector<int> myVector;
    myVector.push_back(10);
    myVector.push_back(20);
    return 0;
}

访问元素

cpp 复制代码
#include <vector>

int main() {
    std::vector<int> myVector = {1, 2, 3, 4, 5};
    int firstElement = myVector[0]; // 访问第一个元素
    return 0;
}

修改元素

cpp 复制代码
#include <vector>

int main() {
    std::vector<int> myVector = {1, 2, 3, 4, 5};
    myVector[2] = 100; // 将第三个元素修改为100
    return 0;
}

删除元素

cpp 复制代码
#include <vector>

int main() {
    std::vector<int> myVector = {1, 2, 3, 4, 5};
    myVector.pop_back(); // 删除最后一个元素
    return 0;
}

获取大小

cpp 复制代码
#include <vector>

int main() {
    std::vector<int> myVector = {1, 2, 3, 4, 5};
    int size = myVector.size(); // 获取vector的大小
    return 0;
}

vector 的性能分析

时间复杂度

  • push_back()pop_back():平均情况下为 O(1)。
  • at():平均情况下为 O(1)。
  • front()back():平均情况下为 O(1)。
  • operator[]:平均情况下为 O(1)。
  • erase():平均情况下为 O(n),因为可能需要移动后续元素。
  • insert():平均情况下为 O(n),因为可能需要移动后续元素。

空间复杂度

vector的空间复杂度取决于其存储的元素数量。在添加元素时,vector会自动增加其容量,这可能会导致额外的内存分配。

vector 的注意事项

  • vector不会自动释放内存,所以你需要确保在不再需要时使用clear()或析构函数来释放内存。
  • 在添加大量元素时,vector可能会进行多次内存分配和复制,这可能会导致性能问题。在这种情况下,可以考虑使用其他容器,如std::dequestd::list

总结

vector是C++中非常强大和常用的容器之一。它提供了动态数组的功能,支持随机访问和大小可变。在处理大量数据时,vector是一个很好的选择。然而,在使用vector时,需要注意性能和内存管理问题。

相关推荐
止语Lab12 小时前
Go并发编程实战:Channel 还是 Mutex?一个场景驱动的选择框架
开发语言·后端·golang
她说彩礼65万13 小时前
C# 实现简单的日志打印
开发语言·javascript·c#
绿浪198413 小时前
c# 中结构体 的定义字符串字段(性能优化)
开发语言·c#
房开民13 小时前
可变参数模板
java·开发语言·算法
t***54413 小时前
如何在现代C++中更有效地应用这些模式
java·开发语言·c++
Victoria.a15 小时前
python基础语法
开发语言·python
xiaoyaohou1115 小时前
023、数据增强改进(二):自适应数据增强与AutoAugment策略
开发语言·python
鬼圣15 小时前
Python 上下文管理器
开发语言·python
星空椰16 小时前
JavaScript 基础进阶:分支、循环与数组实战总结
开发语言·javascript·ecmascript
yong999016 小时前
IHAOAVOA:天鹰优化算法与非洲秃鹫优化算法的混合算法(Matlab实现)
开发语言·算法·matlab