01、array

C++ 容器类 array

  • C++11 标准引入了 头文件,它提供了一种固定大小的数组容器
  • 与 C 语言中的数组相比,具有更好的类型安全和内存管理特性
  • std::array 是 C++ 标准库中的一个模板类,它定义在 头文件中
  • std::array 模板类提供了一个固定大小的数组,其大小在编译时确定,并且不允许动态改变

特点
  • 类型安全:std::array 强制类型检查,避免了 C 语言数组的类型不安全问题。
  • 固定大小:数组的大小在编译时确定,不能在运行时改变。
  • 内存连续:std::array 的元素在内存中是连续存储的,这使得它可以高效地访问元素。
  • 标准容器:std::array 提供了与 std::vector 类似的接口,如 size(), at(), front(), back() 等。

常见的成员函数
函数说明
at(size_t pos)返回指定位置的元素,带边界检查
operator[]返回指定位置的元素,不带边界检查
front()返回数组的第一个元素
back()返回数组的最后一个元素
data()返回指向数组数据的指针
size()返回数组大小(固定不变)
fill(const T& value)将数组所有元素设置为指定值
swap(array& other)交换两个数组的内容
begin() / end()返回数组的起始/结束迭代器

与其他数组类型对比
特性std::arrayC 风格数组std::vector
大小编译时固定编译时固定动态可变
边界检查at() 提供边界检查at() 提供边界检查
内存管理栈上分配栈上分配堆上分配
性能高效高效较低(动态分配)
接口支持 STL 标准接口不支持 STL 标准接口支持 STL 标准接口

应用场景
  1. 固定大小数组:需要固定大小的数组,如存储传感器数据。
  2. 嵌入式系统:内存受限的嵌入式系统,如微控制器中的数据存储。
  3. 静态数据:存储静态数据,如常量表或查找表。
  4. 多维数组:实现多维数组,如矩阵运算。
  5. 性能关键:需要高性能的场景,如实时系统中的数据处理。

底层
  • 底层数据结构:静态数组
  • 静态数组的介绍,增删查改的时间复杂度和空间复杂度分别是:
  • 插入:时间复杂度为 O(1),空间复杂度为 O(n)
  • 删除:时间复杂度为 O(1),空间复杂度为 O(n)
  • 访问:时间复杂度为 O(1),空间复杂度为 O(n)
  • 修改:时间复杂度为 O(1),空间复杂度为 O(n)

代码示例-01
#include <iostream>
#include <array>

int main() {
    // 创建一个包含 5 个整数的 std::array
    std::array<int, 5> myArray = {1, 2, 3, 4, 5};

    // 使用范围 for 循环遍历数组
    for (const auto& value : myArray) {
        std::cout << value << " ";
    }
    std::cout << std::endl;

    // 使用索引访问数组元素
    std::cout << "Element at index 2: " << myArray.at(2) << std::endl;

    // 获取数组的大小
    std::cout << "Array size: " << myArray.size() << std::endl;

    // 修改数组元素
    myArray[3] = 10;

    // 再次遍历数组以显示修改后的元素
    for (const auto& value : myArray) {
        std::cout << value << " ";
    }
    std::cout << std::endl;

    return 0;
}

/*
1 2 3 4 5 
Element at index 2: 3
Array size: 5
1 2 3 10 5 
*/

代码示例-02 (基本操作)
#include <iostream>
#include <array>

int main() {
    std::array<int, 5> arr = {10, 20, 30, 40, 50};

    std::cout << "Array elements: ";
    for (int i = 0; i < arr.size(); ++i) {
        std::cout << arr[i] << " ";
    }
    std::cout << std::endl;

    // 获取第一个和最后一个元素
    std::cout << "First element: " << arr.front() << std::endl;
    std::cout << "Last element: " << arr.back() << std::endl;

    return 0;
}

代码示例-03 (使用at和边界检查)
#include <iostream>
#include <array>

int main() {
    std::array<int, 3> arr = {1, 2, 3};

    try {
        std::cout << arr.at(2) << std::endl;  // 正常输出
        std::cout << arr.at(5) << std::endl;  // 超出范围,抛出异常
    } catch (const std::out_of_range& e) {
        std::cout << "Exception: " << e.what() << std::endl;
    }

    return 0;
}

代码示例-04 (使用fill填充元素)
#include <iostream>
#include <array>

int main() {
    std::array<int, 5> arr;
    arr.fill(100);  // 将所有元素设置为100

    std::cout << "Filled array: ";
    for (const auto& elem : arr) {
        std::cout << elem << " ";
    }
    std::cout << std::endl;

    return 0;
}

代码示例-05 (数组交换)
#include <iostream>
#include <array>

int main() {
    std::array<int, 3> arr1 = {1, 2, 3};
    std::array<int, 3> arr2 = {4, 5, 6};

    arr1.swap(arr2);

    std::cout << "Array 1: ";
    for (const auto& elem : arr1) {
        std::cout << elem << " ";
    }
    std::cout << std::endl;

    std::cout << "Array 2: ";
    for (const auto& elem : arr2) {
        std::cout << elem << " ";
    }
    std::cout << std::endl;

    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

虚拟之

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值