【C++】std::vector

std::vector:

std::vector 是 C++ 标准库中的一个动态数组容器,它提供了一个可以动态调整大小的数组。std::vector 是一个非常常用的容器,主要用于存储和管理元素的集合,并且支持高效的随机访问和动态调整大小。

基本特性

  1. 动态大小 : std::vector 可以根据需要动态地增加或减少大小,自动管理内存。
  2. 随机访问 : 支持高效的随机访问,通过 operator[]at() 方法可以直接访问元素。
  3. 连续存储 : 内部存储是连续的,这使得 std::vector 支持快速的元素访问和高效的缓存性能。
  4. 自动管理内存 : std::vector 会自动管理内存,不需要用户手动释放内存。

常用操作

以下是一些 std::vector 的常用操作及其示例:

1. 创建 std::vector
cpp 复制代码
#include <vector>

int main() {
    // 创建一个空的 vector,元素类型为 int
    std::vector<int> vec1;

    // 创建一个初始化为 10 个元素的 vector,元素值为 0
    std::vector<int> vec2(10);

    // 创建一个初始化为 10 个元素的 vector,元素值为 5
    std::vector<int> vec3(10, 5);

    // 使用初始化列表创建 vector
    std::vector<int> vec4 = {1, 2, 3, 4, 5};
    
    return 0;
}
2. 访问和修改元素
cpp 复制代码
#include <vector>
#include <iostream>

int main() {
    std::vector<int> vec = {10, 20, 30, 40, 50};

    // 通过下标访问
    std::cout << "Element at index 2: " << vec[2] << std::endl;

    // 使用 at() 方法访问,提供边界检查
    std::cout << "Element at index 3: " << vec.at(3) << std::endl;

    // 修改元素
    vec[2] = 100;
    std::cout << "Modified element at index 2: " << vec[2] << std::endl;

    return 0;
}
3. 添加和删除元素
cpp 复制代码
#include <vector>
#include <iostream>

int main() {
    std::vector<int> vec;

    // 添加元素到末尾
    vec.push_back(10);
    vec.push_back(20);
    vec.push_back(30);

    std::cout << "Vector size after push_back: " << vec.size() << std::endl;

    // 删除末尾元素
    vec.pop_back();

    std::cout << "Vector size after pop_back: " << vec.size() << std::endl;

    // 清空所有元素
    vec.clear();
    std::cout << "Vector size after clear: " << vec.size() << std::endl;

    return 0;
}
4. 遍历 std::vector
cpp 复制代码
#include <vector>
#include <iostream>

int main() {
    std::vector<int> vec = {1, 2, 3, 4, 5};

    // 使用范围 for 循环
    for (const auto& elem : vec) {
        std::cout << elem << " ";
    }
    std::cout << std::endl;

    // 使用迭代器遍历
    for (auto it = vec.begin(); it != vec.end(); ++it) {
        std::cout << *it << " ";
    }
    std::cout << std::endl;

    return 0;
}
5. 其他常用方法
  • size() : 返回 vector 中元素的数量。
  • capacity() : 返回 vector 当前分配的内存容量(即当前可以容纳多少个元素而不需要重新分配内存)。
  • empty() : 判断 vector 是否为空。
  • reserve(): 预留一定的内存容量,减少重新分配的次数。
  • resize() : 改变 vector 的大小,并且可以用新大小填充默认值。

示例 :

cpp 复制代码
#include <vector>
#include <iostream>

int main() {
    std::vector<int> vec = {1, 2, 3, 4, 5};

    // 输出容量
    std::cout << "Initial capacity: " << vec.capacity() << std::endl;

    // 增加元素
    vec.push_back(6);

    // 输出容量
    std::cout << "Capacity after adding one element: " << vec.capacity() << std::endl;

    // 预留空间
    vec.reserve(20);
    std::cout << "Capacity after reserving space for 20 elements: " << vec.capacity() << std::endl;

    // 调整大小
    vec.resize(10, 0);
    std::cout << "Size after resizing to 10: " << vec.size() << std::endl;

    return 0;
}

在这段代码中,vec.resize(10, 0); 语句将 vec 的大小调整为 10。如果 vec 的当前大小小于 10,resize 方法会在末尾添加元素,新增的元素会被初始化为 0。如果 vec 的当前大小已经大于等于 10,resize 方法会将多余的元素移除,以使大小变为 10。

在调整大小后,std::cout << "Size after resizing to 10: " << vec.size() << std::endl; 语句将输出 vec 的新大小,也就是 10

相关推荐
jllllyuz几秒前
MATLAB雷达系统设计与仿真
开发语言·matlab
IMPYLH1 分钟前
Lua 的 type 函数
开发语言·笔记·后端·junit·lua
老华带你飞12 分钟前
英语学习|基于Java英语学习系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端·学习
qq_4798754314 分钟前
C++ 模板元编程
java·开发语言·c++
codingPower15 分钟前
Java EasyExcel创建复杂表格的完整指南:WriteTable
java·开发语言
爱装代码的小瓶子17 分钟前
【cpp知识铺子】map与set的底层AVL树
开发语言·数据结构·c++·b树·算法·链表
IT·小灰灰18 分钟前
腾讯HY2.0 Think推理模型深度解析:技术突破、应用场景与实践指南
开发语言·人工智能·python·深度学习·神经网络·算法·数据分析
源代码•宸19 分钟前
100 Go Mistakes(#4 过度使用getter和setter、#5 接口污染)
开发语言·经验分享·后端·golang
修炼地27 分钟前
代码随想录算法训练营第二十八天 | 动态规划理论基础、509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
c++·算法·动态规划
某空m30 分钟前
【Android】浅析DataBinding
android·开发语言