【c/c++】 学习vector 容器笔记

c/c++ 学习vector 容器笔记

  • int 型的 vector 容器应该使用什么类型的索引?

对于 int 型的 vector 容器,应该使用 size_t 类型的索引。size_t 是一个无符号整数类型,它在标准库中广泛用于表示大小和索引。它足够大,可以表示任何标准容器的最大可能大小。

例如,访问 vector 中的元素时,你可以这样做:

复制代码
std::vector<int> vec = {1, 2, 3, 4, 5};
size_t index = 2; // 使用 size_t 作为索引
if (index < vec.size()) {
    std::cout << "Element at index " << index << " is " << vec[index] << std::endl;
}

在这个例子中,index 是 size_t 类型的变量,它被用来访问 vec 中的元素。使用 size_t 作为索引类型可以避免潜在的类型不匹配问题,并且与标准库容器的 size() 方法返回的类型保持一致。

  • 读取存放 string 对象的 list 容器时,应该使用什么类型?

读取存放 string 对象的 list 容器时,你应该使用 std::liststd::string::const_iterator 类型的迭代器。如果你需要修改容器中的元素,可以使用 std::liststd::string::iterator。以下是使用迭代器遍历 list 容器并读取 string 对象的示例代码:

复制代码
#include <iostream>
#include <list>
#include <string>

int main() {
    std::list<std::string> lst = {"Hello", "World", "from", "list"};

    // 使用 const_iterator 遍历 list 容器
    for (std::list<std::string>::const_iterator it = lst.cbegin(); it != lst.cend(); ++it) {
        std::cout << *it << std::endl; // 输出当前迭代器指向的 string 对象
    }

    return 0;
}

在这个例子中,我们使用 cbegin() 和 cend() 成员函数来获取指向 list 容器的常量迭代器,这样我们就可以在不修改元素的情况下读取它们。如果需要修改元素,可以使用 begin() 和 end() 成员函数来获取可修改的迭代器。

注意,使用迭代器时,你通常不需要显式地声明迭代器的类型,因为 C++11 引入了自动类型推导(auto 关键字)。例如:

复制代码
for (auto it = lst.cbegin(); it != lst.cend(); ++it) {
    std::cout << *it << std::endl;
}

这使得代码更加简洁和易于阅读。

相关推荐
是烟花哈34 分钟前
【前端】React框架学习
前端·学习·react.js
[J] 一坚34 分钟前
嵌入式高手C
c语言·开发语言·stm32·单片机·mcu·51单片机·iot
檀越剑指大厂37 分钟前
32 万星的面试学习计划 + 内网穿透工具,程序员面试准备效率翻倍!
学习·面试·职场和发展
借雨醉东风44 分钟前
程序分享--常见算法/编程面试题:旋转矩阵
c++·线性代数·算法·面试·职场和发展·矩阵
云泽8082 小时前
笔试算法 - 双指针篇(二):四大经典求和题型 + 有效三角形计数问题
c++·算法
YangYang9YangYan3 小时前
2026年工作后学习数据分析的价值与路径
学习·数据挖掘·数据分析
十五年专注C++开发3 小时前
WaitingSpinnerWidget: 一个高度可配置的自定义Qt等待加载动画组件
开发语言·c++·qt·waitingspinner
qeen873 小时前
【数据结构】树的基本概念及存储
c语言·数据结构·c++·学习·
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【区间贪心】:种树
c++·算法·贪心·csp·信奥赛·区间贪心·种树
hi_ro_a3 小时前
C++ 哈希表封装 unordered_map /unordered_set
数据结构·c++·算法·哈希算法