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时,需要注意性能和内存管理问题。

相关推荐
Je1lyfish10 分钟前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
Brilliantwxx25 分钟前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法
野生技术架构师25 分钟前
2026年最全Java面试题及答案汇总(建议收藏,面试前看这篇就够了)
java·开发语言·面试
百锦再1 小时前
Auto.js变成基础知识学习
开发语言·javascript·学习·sqlite·kotlin·android studio·数据库开发
叼烟扛炮1 小时前
C++第三讲:类和对象(中)
开发语言·c++·类和对象
iDao技术魔方2 小时前
DeepSeek TUI:原生 Rust 打造的终端 AI 编码 Agent
开发语言·人工智能·rust
jghhh012 小时前
认知无线电中基于能量检测的双门限频谱感知的 MATLAB 仿真
开发语言·matlab
Mr数据杨2 小时前
【Codex】用教案主体模块沉淀标准化教学设计内容
java·开发语言·django·codex·项目开发
wangbing11252 小时前
踩坑:el8应用装在el9上
开发语言·后端·ruby
Andya_net3 小时前
Java | Java内存模型JMM
java·开发语言