《21天学通C++》(第十五章)标准模板库简介

本章简单介绍STL容器、迭代器和算法的基本概念,之后几章会分别详述

1.STL容器

STL容器是STL中用于存储集合数据的组件,它们可以被看作是模板类,允许开发者定义特定类型的容器发,这里按照C++11标准分为四类:顺序容器、关联容器、无序容器、容器适配器

使用STL的好处有:

  • 泛型编程: 容器和算法的模板化使得它们可以用于多种数据类型
  • 代码重用: STL提供了通用的数据结构和算法,减少代码重复
  • 性能: STL容器的实现通常为高效的数据结构,如动态数组、平衡二叉树搜索等

2.顺序容器

按顺序存储数据,具有插入速度快、查找相对慢的特点

  • vector: 动态数组,可以高效地在任意位置插入和删除元素,在尾部插入速度最快,支持随机访问。
  • deque: 双端队列,可以高效地在两端插入和删除元素。
  • list: 双向链表,可以高效地在任意位置插入和删除元素。
  • forward_list: 单向链表,只能沿着一个方向遍历

3.关联容器

按指定顺序存储键值对,通过键来访问元素,具有查询速度快、插入相对慢的特点

  • set: 存储唯一的值,插入时元素自动排序。
  • map: 由键值对组成的集合,插入时元素根据唯一键自动排序。
  • multiset: 允许多个相同值的项,插入时元素自动排序
  • multimap: 不要求键唯一,插入时会自动排序

4.无序容器

C++11引入的新容器,不保证元素顺序,大多数情况下性能更高

  • unordered_set: 与set类似,但无序,容器复杂度为常数
  • unordered_map: 与map类似,但无序
  • unordered_multiset: 与multiset类似,但无序
  • unordered_multimap: 与multimap类似,但无序

5.容器适配器

时顺序容器和关联容器的变种,提供了特定的接口来操作底层的容器,用以满足特定需求

  • stack: 后进先出(LIFO)的栈。
  • queue: 先进先出(FIFO)的队列。
  • priority_queue: 优先队列,元素根据优先级排序。

6.STL迭代器

提供了一种统一的方式来访问和操作各种容器中的元素,迭代器可以被视为一种泛型的指针,允许你间接地引用容器中的每个元素,从而遍历容器。

  • 输入迭代器(Input Iterators): 可以读取序列中的每个元素一次。
  • 输出迭代器(Output Iterators): 可以写入序列中的每个元素一次。
  • 前向迭代器(Forward Iterators): 提供单向遍历能力,只读或读写,可以读取每个元素,且可以多次读取,通常用于单向链表。
  • 双向迭代器(Bidirectional Iterators): 除了前向遍历,还可以反向遍历,通常用于双向链表。
  • 随机访问迭代器(Random AccessIterators): 提供完全的随机访问能力,可以快速访问任何元素,支持复杂的操作如随机访问、元素交换等,通常用于数组。

7.STL算法

非修改算法:
①find:在容器中查找特定元素的第一个匹配项。
②find_if:查找第一个满足特定条件的元素。
③count:计算容器中满足特定条件的元素数量。
④distance:计算两个迭代器之间的距离。

修改算法:
①fill:用特定值填充容器的某个范围。
②copy:将一个范围的元素复制到另一个容器。
③remove:从容器中移除特定值
④remove_if:移除容器中满足某个特定条件的元素
⑤reverse:反转容器中的元素顺序。

排序算法:
①sort:对容器中的元素进行排序。
②stable_sort:对容器中的元素进行稳定的排序。

集合算法:
①set_union:计算两个集合的并集。
②set_intersection:计算两个集合的交集。
③set_difference:计算两个集合的差集。
④set_symmetric_difference:计算两个集合的对称差集。

数值算法:
①accumulate:计算容器中元素的总和或满足特定操作的结果。
②inner_product:计算两个容器元素的内积。
③partial_sum:计算容器元素的部分和。

配对算法:
①mismatch:查找两个容器中第一个不匹配的元素。
②equal:比较两个容器或范围中的元素是否相等。

搜索算法:
①search:在一个大容器中搜索一个小容器的元素序列。
②search_n:搜索一个容器中包含特定数量的某个值的子序列。

变换算法:
transform:将某种操作应用到每个元素上。

流算法:
for_each:对容器中的每个元素执行特定的操作。

适配器:
std::sort 通常与 std::less 或其他比较函数对象一起使用,作为算法的适配器。

8.使用迭代器在容器和算法之间交互

迭代器是连接容器和算法的桥梁,它们允许算法在不知道底层容器类型的情况下操作容器中的元素

例子

#include <iostream>
#include <vector>
#include <algorithm> 
// 定义一个简单的函数,用于打印一个整数
void print_number(int number) {
    std::cout << number << " ";
}

int main() {
    // 创建一个整数类型的 vector 容器
    std::vector<int> numbers = {10, 20, 30, 40, 50};

    // 使用 std::for_each 算法,对一个序列中的每个元素执行某种操作
    //numbers.begin()返回一个迭代器,指向 numbers 容器中第一个元素的位置
    //numbers.end()返回一个迭代器,指向 numbers 容器中最后一个元素之后的位置
    //即对numbers序列中的每一个元素执行print_number
    std::for_each(numbers.begin(), numbers.end(), print_number);

    // 输出
    std::cout << std::endl;
    system("pause");
    return 0;
}

9.选择正确的容器

在这里插入图片描述

10.STL字符串类

可以用于创建不同的字符串类型

相关推荐

  1. 21C++》()实现继承(2)

    2024-05-04 18:44:02       11 阅读
  2. 21C++》() 类型转换运算符

    2024-05-04 18:44:02       10 阅读
  3. 21C++》()STL list和forward_list

    2024-05-04 18:44:02       9 阅读
  4. 21C++》(第二)理解函数对象

    2024-05-04 18:44:02       12 阅读
  5. 21C++》实现继承(1)

    2024-05-04 18:44:02       15 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-04 18:44:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-04 18:44:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-04 18:44:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-04 18:44:02       20 阅读

热门阅读

  1. springcloud(智慧养老平台)

    2024-05-04 18:44:02       13 阅读
  2. codeforces round 879 div2 (a,b,c)

    2024-05-04 18:44:02       12 阅读
  3. 第Ⅰ章-V package.json文件详解

    2024-05-04 18:44:02       10 阅读
  4. 爬⾍监控与⾃动恢复机制

    2024-05-04 18:44:02       8 阅读
  5. Nodejs-异步并发控制

    2024-05-04 18:44:02       9 阅读
  6. 分割等和子集

    2024-05-04 18:44:02       10 阅读
  7. Vue3 + TS + Element-Plus 封装的 Table 表格组件

    2024-05-04 18:44:02       10 阅读
  8. python调用微信自带OCR实现内容识别(全)

    2024-05-04 18:44:02       12 阅读
  9. 2024.4.28力扣每日一题——负二进制转换

    2024-05-04 18:44:02       12 阅读
  10. OneFlow深度学习框架入门与实践

    2024-05-04 18:44:02       9 阅读