STL的六大组件

news2024/12/23 3:12:59

一.总体概念

STL(Standard Template Library,标准模板库)是C++标准库的一部分,提供了丰富且高效的数据结构和算法。STL主要由六大组件组成,它们是:

  1. 容器(Containers):STL提供了多种不同类型的容器,如vector、list、deque、set、map等,用于存储和管理数据。这些容器提供了不同的特性和性能,可以根据具体需求选择合适的容器。

  2. 算法(Algorithms):STL包含了大量的算法,如排序、查找、遍历等,可以在不同的容器上进行操作。这些算法具有高度的重用性和通用性,帮助开发者快速实现各种常见的操作。

  3. 迭代器(Iterators):迭代器是STL中用于遍历容器元素的工具,提供了统一的访问接口,使得算法可以以通用的方式操作各种容器。迭代器分为输入迭代器、输出迭代器、正向迭代器、双向迭代器和随机访问迭代器等不同类型。

  4. 仿函数(Functors):仿函数是STL中的一个重要概念,它允许将函数对象作为参数传递给算法,从而实现更加灵活和通用的操作。STL提供了一些内置的仿函数,同时也支持用户自定义的仿函数。

  5. 适配器(Adapters):适配器可以在已有的容器或算法之间提供一个接口层,以实现不同组件之间的互操作。常见的适配器有stack、queue和priority_queue等,它们提供了不同的数据结构和访问方式。

  6. 分配器(Allocators):分配器是STL中用于内存管理的组件,负责为容器分配和释放内存。STL中的容器在实现时通常使用分配器进行内存分配,不同的分配器可以满足不同的内存分配策略和需求。

这些组件共同构成了STL的核心部分,为C++程序提供了强大、高效且通用的数据结构和算法支持。使用STL可以提高代码的可读性、可维护性和性能,并加速开发过程。

在这里插入图片描述

二.详细分析

1.容器

multimap和multiset介绍

Multimap和Multiset都是关联容器,允许存储多个相同键值的元素,但它们之间存在一些区别。

  1. Multimap(多映射):
  • Multimap是一个有序容器,它使用红黑树(Red-Black Tree)作为底层实现,元素按键值自动排序。
  • 允许存储多个相同键值的元素,可以通过键值快速查找对应的元素。
  • 插入新元素时,并不会覆盖掉已存在的相同键值元素,而是将新元素插入到相同键值元素的后面。
  • 提供了插入、删除、查找等操作,时间复杂度为O(log n)。
  • 示例:
#include <iostream>
#include <map>

int main() {
    std::multimap<int, std::string> myMultimap;

    myMultimap.insert(std::make_pair(1, "apple"));
    myMultimap.insert(std::make_pair(2, "banana"));
    myMultimap.insert(std::make_pair(1, "avocado"));

    for (const auto& pair : myMultimap) {
        std::cout << pair.first << ": " << pair.second << std::endl;
    }

    return 0;
}

输出:

1: apple
1: avocado
2: banana
  1. Multiset(多集合):

Multiset是一种有序容器,允许存储多个相同的元素,并且会保持元素插入的顺序。在Multiset中,相同的元素会被当作不同的元素存储,即允许存在多个相同的元素。

因此,Multiset允许存储多个相同的元素,并且会按照插入的顺序保持这些元素,但不会有重复的元素。

  • Multiset也是一个有序容器,底层同样使用红黑树进行实现,但存储的是无重复的元素集合。
  • 允许存储多个相同的元素,插入时会保持元素的顺序,但不会有重复的元素。
  • 提供了插入、删除、查找等操作,时间复杂度为O(log n)。
  • 示例:
#include <iostream>
#include <set>

int main() {
    std::multiset<int> myMultiset;

    myMultiset.insert(1);
    myMultiset.insert(2);
    myMultiset.insert(1);

    for (const auto& value : myMultiset) {
        std::cout << value << std::endl;
    }

    return 0;
}

输出:

1
1
2

总结:Multimap和Multiset在STL中提供了方便的操作多个相同键值的元素和无重复元素集合的功能,适用于需要按照特定顺序存储、查找和操作元素的情况。通过了解它们的区别和特性,可以更好地选择适合的容器来满足编程需求。

2. 算法

merge函数介绍

merge是STL中的一个算法,用于将两个已排好序的序列合并成一个有序序列。该算法会合并两个序列,并将结果存储在目标序列中。以下是merge算法的详细介绍:

  • 函数签名:
template <class InputIterator1, class InputIterator2, class OutputIterator>
OutputIterator merge(InputIterator1 first1, InputIterator1 last1,
                     InputIterator2 first2, InputIterator2 last2,
                     OutputIterator result);
 
参数:
first1, last1: 第一个有序序列的起始和结束迭代器。
first2, last2: 第二个有序序列的起始和结束迭代器。
result: 目标序列的起始迭代器,用于存储合并后的有序序列。
返回值:
返回一个迭代器,指向合并后的有序序列最后一个元素之后的位置。
功能:
merge算法将两个已排好序的序列进行合并,并将结果存储在目标序列中。
合并后的序列仍然是有序的。
  • 使用示例:
#include <iostream>
#include <algorithm>
#include <vector>

int main() {
    std::vector<int> v1 = {1, 3, 5, 7};
    std::vector<int> v2 = {2, 4, 6, 8};

    std::vector<int> result(v1.size() + v2.size());

    std::merge(v1.begin(), v1.end(), v2.begin(), v2.end(), result.begin());

    for (const auto& num : result) {
        std::cout << num << " ";
    }

    return 0;
}

输出:

1 2 3 4 5 6 7 8

在上面的示例中,我们使用merge算法将两个已排好序的向量v1和v2合并到result中,并输出合并后的有序序列。这样我们可以方便地将两个有序序列合并成一个有序序列。

3.迭代器

迭代器(Iterator)是C++中用来访问容器元素的一种抽象概念。它允许我们以统一的方式遍历各种不同类型的容器,如数组、向量、链表和映射等。下面是一个简单的示例,用于说明迭代器的基本用法:

#include <iostream>
#include <vector>

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

    // 使用迭代器遍历向量并打印元素
    std::cout << "Using iterator to traverse the vector: ";
    for (std::vector<int>::iterator it = v.begin(); it != v.end(); ++it) {
        std::cout << *it << " ";
    }
    std::cout << std::endl;

    return 0;
}

在上面的例子中,我们创建了一个整数向量v并使用迭代器it来遍历它。现在让我解释一下代码中迭代器的用法和相关概念:

  • v.begin()返回指向向量起始元素的迭代器。
  • v.end()返回指向向量末尾下一个位置的迭代器。
  • it是一个迭代器,它初始化为v.begin(),逐步向前遍历直到v.end(),在每一步中,使用*it来获取迭代器当前所在位置的元素值。

上述代码中,我们使用了模板类std::vector的迭代器std::vector::iterator来遍历整数向量v。需要注意的是,C++ 11引入了auto关键字,可以用它来自动推断迭代器的类型,让代码更加简洁:


#include <iostream>
#include <vector>

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

    // 使用 auto 关键字简化迭代器类型
    std::cout << "Using iterator to traverse the vector: ";
    for (auto it = v.begin(); it != v.end(); ++it) {
        std::cout << *it << " ";
    }
    std::cout << std::endl;

    return 0;
}

在这个简化的示例中,我们使用auto关键字自动推断迭代器的类型,并且不需要显式指定std::vector::iterator。

4. 适配器

在C++中,适配器(Adapter)是一种设计模式,用于将一个类的接口转换成另一个类的接口,以满足客户端的需求而不改变原有类的代码。在STL中,有一些适配器容器,可以对其他容器进行适配,提供不同的接口和功能。

下面是几种常见的适配器容器及其功能:

  1. 栈(stack):
  • 栈是一种后进先出(LIFO)的容器,只能在顶部进行插入和删除操作。
  • 使用适配器std::stack可以创建一个栈,基于其他容器(默认是std::deque)实现。
#include <iostream>
#include <stack>

int main() {
    std::stack<int> s;
    
    s.push(10);
    s.push(20);
    s.push(30);

    while (!s.empty()) {
        std::cout << s.top() << " ";
        s.pop();
    }
    
    std::cout << std::endl;

    return 0;
}
输出:30 20 10
  1. 队列(queue):
  • 队列是一种先进先出(FIFO)的容器,支持在队尾插入,在队头删除元素。
  • 使用适配器std::queue可以创建一个队列,基于其他容器(默认是std::deque)实现。
#include <iostream>
#include <queue>

int main() {
    std::queue<int> q;
    
    q.push(10);
    q.push(20);
    q.push(30);

    while (!q.empty()) {
        std::cout << q.front() << " ";
        q.pop();
    }
    
    std::cout << std::endl;

    return 0;
}
输出:10 20 30
  1. 优先队列(priority_queue):
  • 优先队列是一种具有优先级顺序的队列,每次取出的元素都是优先级最高的。
  • 使用适配器std::priority_queue可以创建一个优先队列,默认情况下基于std::vector实现。
#include <iostream>
#include <queue>

int main() {
    std::priority_queue<int> pq;
    
    pq.push(30);
    pq.push(10);
    pq.push(20);

    while (!pq.empty()) {
        std::cout << pq.top() << " ";
        pq.pop();
    }
    
    std::cout << std::endl;

    return 0;
}
输出:30 20 10

以上是几种常见的STL适配器容器以及它们的基本用法。适配器容器可以简化具体容器的操作,并提供了更高层次的功能和接口,方便在实际开发中使用。

5. 仿函数

在C++中,仿函数(function object)是一种类或结构体,可以像函数一样被调用。仿函数可以以类似函数调用的方式使用,将其对象当作函数来调用,这种方式在STL中被广泛应用。

仿函数的特点:

  • 仿函数是一个类或结构体,重载了operator()函数。
  • 仿函数可以带有状态,可以在构造函数中初始化,因此可以用于实现更复杂的逻辑。
  • 仿函数可以作为参数传递给算法或者容器,以自定义比较、排序、筛选等操作。

下面是一个简单的示例,演示如何定义一个仿函数并使用它:

#include <iostream>
#include <algorithm>
#include <vector>

// 定义一个仿函数 LessThan,用于比较两个整数的大小
class LessThan {
public:
    bool operator()(int a, int b) const {
        return a < b;
    }
};

int main() {
    std::vector<int> nums = {5, 2, 8, 1, 6, 3};

    // 使用仿函数 LessThan 对 nums 中的元素进行排序
    std::sort(nums.begin(), nums.end(), LessThan());

    // 输出排序后的结果
    for (int num : nums) {
        std::cout << num << " ";
    }
    std::cout << std::endl;

    return 0;
}

在这个示例中,我们定义了一个仿函数LessThan,其中重载了operator()函数,用于比较两个整数的大小。然后在main函数中,使用LessThan仿函数作为std::sort算法的第三个参数,实现对nums向量中元素的排序。

在实际开发中,仿函数非常灵活,可以根据需求自定义功能,例如自定义排序条件、筛选条件等。通过仿函数,我们可以更加灵活地使用STL算法和容器,满足不同场景下的需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1888532.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

AIGC文生图lora微调训练案例;SD-Train界面训练stable Diffusion lora模型

lora仓库&#xff08;1000多个lora微调模型分享&#xff09;&#xff1a; https://lorastudio.co/models 参考&#xff1a; https://huggingface.co/blog/lora https://github.com/huggingface/diffusers/blob/main/examples/text_to_image/train_text_to_image_lora.py http…

UMI 命令行手册

Translate to English 命令行手册&#xff1a; README_CLI.mdHTTP接口手册&#xff1a; README_HTTP.md 命令行手册 基础说明 命令行调用入口就是主程序 Umi-OCR.exe 。如果你使用的是备用启动器&#xff08;如UmiOCR-data/RUN_GUI.bat&#xff09;&#xff0c;可能无法使用…

【TS】TypeScript 原始数据类型深度解析

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 TypeScript 原始数据类型深度解析一、引言二、基础原始数据类型2.1 boolean2.2 …

推荐系统三十六式学习笔记:原理篇.MAB问题|16|简单却有效的Bandit算法

目录 推荐就是选择MAB问题Bandit算法1.汤普森采样算法2.UCB算法3.Epsilon贪婪算法4.效果对比 冷启动总结 推荐系统的使命就是建立用户和物品之间的连接。建立连接可以理解成;为用户匹配到最佳的物品&#xff1b;但也有另一个理解就是&#xff0c;在某个时间某个位置为用户选择最…

彩虹PLM系统:电子制造业的高效协同平台

彩虹PLM系统&#xff1a;电子制造业的高效协同平台 在当今竞争激烈的电子制造业中&#xff0c;企业亟需一种能够整合全生命周期数据、促进跨部门协同并提升生产效率的解决方案。彩虹PLM系统&#xff0c;作为产品生命周期管理的佼佼者&#xff0c;凭借其卓越的技术实力和丰富的行…

前端基础--Vue3

Vue3基础 VUE3和VUE2的区别 2020年9月18日&#xff0c;Vue.js发布版3.0版本&#xff0c;代号&#xff1a;One Piece 于 2022 年 2 月 7 日星期一成为新的默认版本! Vue3性能更高,初次渲染快55%, 更新渲染快133% 。体积更小 Vue3.0 打包大小减少41%。 同时Vue3可以更好的支持T…

AI 影评生成

电影作为一种重要的艺术形式&#xff0c;承载着无穷的想象力和情感表达。它不仅是娱乐的载体&#xff0c;更是一面照亮人性、社会和历史的镜子。通过电影&#xff0c;观众可以体验不同的世界、感受各种情感&#xff0c;甚至找到共鸣和启发。在这个充满多样性和创意的电影世界中…

自养号测评:引领跨境电商新纪元的策略与实践

在跨境电商的浩瀚蓝海中&#xff0c;自养号测评如同一股不可忽视的潮流&#xff0c;正悄然重塑着行业的未来。这一策略通过精心培育海外买家账号&#xff0c;不仅有效规避了服务商测评的诸多风险&#xff0c;更成为众多卖家提升产品销量与口碑的黑科技运营武器。 核心科技&…

支付宝服务商支付,如何邀请商户入驻?

支付宝服务商支付&#xff1a;如何邀请商户入驻 一、支付宝服务商支付 支付宝服务商支付模式为商户带来了诸多优势。它能够整合多种支付方式&#xff0c;包括扫码支付、刷脸支付、线上支付等&#xff0c;满足不同消费者的支付习惯。同时&#xff0c;提供了强大的财务管理功能…

【MindSpore学习打卡】应用实践-计算机视觉-ShuffleNet图像分类:从理论到实践

在当今的深度学习领域&#xff0c;卷积神经网络&#xff08;CNN&#xff09;已经成为图像分类任务的主流方法。然而&#xff0c;随着网络深度和复杂度的增加&#xff0c;计算资源的消耗也显著增加&#xff0c;特别是在移动设备和嵌入式系统中&#xff0c;这种资源限制尤为突出。…

数据结构(JAVA)—代码题

01-数据结构—判断题 02-数据结构—选择题 03 数据结构—多选填空程序填空 ​ 01-顺序表的建立及遍历 import java.util.Iterator; import java.util.LinkedList; import java.util.ListIterator; import java.util.Scanner;public class Main {public static void main(St…

有哪些好的 Stable Diffusion 提示词(Prompt)可以参考?

Docker 作图咒语生成器 docker-prompt-generator 是一个开源项目&#xff0c;可以利用模型反推出提示词&#xff0c;让你偷偷懒&#xff0c;无需琢磨怎么写prompt&#xff0c;只需要找一个差不多的模型反推一下&#xff0c;直接用就好了&#xff0c;支持支持 MidJourney、Stab…

《Linux开发笔记》C语言编译

C语言编译过程 编译过程主要分为四步&#xff1a;预处理、编译、汇编、链接 预处理&#xff1a;主要用于查找头文件、展开宏 编译&#xff1a;把.i文件编译成.s文件 汇编&#xff1a;把.s文件汇编为.o文件 链接&#xff1a;把多个.o文件链接成一个app 以上四个步骤主要由3个命…

颅内感染性疾病患者就诊指南

颅内感染性疾病&#xff0c;即病原体侵入中枢神经系统&#xff0c;导致脑部或脑膜发生炎症的疾病。这些病原体可能是细菌、病毒、真菌或寄生虫等。颅内感染不仅会对脑组织造成损害&#xff0c;还可能引发一系列严重的并发症&#xff0c;如癫痫发作、意识障碍等 颅内感染性疾病的…

电子邮件OTP验证身份认证接口API服务商比较

电子邮件OTP验证身份认证接口API服务商如何正确选择&#xff1f; 电子邮件OTP验证是一种广泛应用且安全的身份认证方式。AokSend将比较几家主要的电子邮件OTP验证身份认证接口API服务商&#xff0c;帮助企业选择合适的解决方案。 电子邮件OTP&#xff1a;验证优势 可以为用户…

UE4_材质_材质节点_DepthFade

一、DepthFade参数 DepthFade&#xff08;深度消退&#xff09;表达式用来隐藏半透明对象与不透明对象相交时出现的不美观接缝。 项目说明属性消退距离&#xff08;Fade Distance&#xff09;这是应该发生消退的全局空间距离。未连接 FadeDistance&#xff08;FadeDistance&a…

数字时代的巨变!互联网思维与按效果付费的超强联合!

数字时代企业转型的重大变革 家人们&#xff0c;今天来聊聊数字时代企业数字化转型那些事儿&#xff01; 在这个时代&#xff0c;企业数字化转型已经是必然趋势啦。蚓链数字化生态系统在帮助企业在转型过程中采用互联网思维&#xff0c;再加上按效果付费的商业交付模式&#xf…

小程序开发平台版源码系统——万能门店小程序功能 前后端分离 带完整的安装代码包以及搭建教程

系统概述 在移动互联网的浪潮中&#xff0c;小程序以其轻量、便捷、无需下载即可使用的特点&#xff0c;迅速成为连接用户与商家的新桥梁。为了满足广大商家快速搭建个性化、高效运营的小程序需求&#xff0c;我们精心打造了“小程序开发平台版源码系统——万能门店小程序功能…

【经典算法题】两数之和

暴力解法 两层for循环&#xff0c;O(n*n) 优化解法 哈希&#xff0c;O(n) class Solution {public int[] twoSum(int[] nums, int target) {Map<Integer, Integer> hashtable new HashMap<Integer, Integer>();for (int i 0; i < nums.length; i) {if (ha…

【Hec-Ras】第一期:软件安装

Hec-Ras软件安装 1 HEC-RAS软件介绍2 HEC-RAS软件下载3 HEC-RAS软件安装4 HEC-RAS软件界面介绍参考 1 HEC-RAS软件介绍 HEC-RAS 是美国陆军工程兵团工程水文中心&#xff08; Hydrologic Engineering Centers, HEC&#xff09;开发的河道水力计算程序&#xff08;River Analys…