c++ STL系列——(六)multimap

2024-02-13 14:20
文章标签 c++ 系列 stl multimap

本文主要是介绍c++ STL系列——(六)multimap,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C++标准模板库(STL)是C++编程中不可或缺的一部分,它提供了一系列的容器、算法和函数模板,以简化常见的数据结构和算法的实现。在STL中,multimap是一个非常有用的容器,它提供了一种键值对的存储方式,并允许一个键对应多个值。本文将深入介绍multimap的特性、用法和一些示例。

 

概述

multimap是一个关联容器,它在内部使用红黑树实现,具有自动排序的功能。与map不同的是,multimap允许一个键对应多个值,这使得它成为处理具有重复键的情况下的理想选择。

头文件

#include <map>

基本操作

创建一个multimap对象的方式如下:

multimap<Key, Value> myMultimap;

其中,Key和Value分别是键和值的类型。multimap的元素是以键值对(pair)的形式存储的。

 

向multimap中插入元素可以使用insert()函数:

myMultimap.insert(make_pair(key, value));

make_pair()函数可以将键和值组成一个pair对象。

 

遍历multimap

使用迭代器可以遍历multimap的所有元素:

multimap<Key, Value>::iterator it;
for (it = myMultimap.begin(); it != myMultimap.end(); ++it) {cout << "Key: " << it->first << ", Value: " << it->second << endl;
}

通过it->first和it->second可以分别获取键和值。

 

查找元素

multimap提供了多种方式来查找元素,其中最常用的是equal_range()函数:

pair<multimap<Key, Value>::iterator, multimap<Key, Value>::iterator> range;
range = myMultimap.equal_range(key);

这将返回一个pair对象,包含了指向与给定键匹配的元素范围的迭代器。可以使用循环遍历这个范围来获取所有匹配的键值对。

 

删除元素

要删除multimap中的元素,可以使用erase()函数:

myMultimap.erase(key);

这将删除所有键等于key的元素。

 

示例应用

学生成绩管理 假设我们需要管理学生的姓名和成绩,由于可能存在重名的情况,我们可以使用multimap来存储数据。下面是一个示例程序:

#include <iostream>
#include <map>
using namespace std;int main() {multimap<string, int> studentScores;// 添加学生成绩studentScores.insert(make_pair("Alice", 85));studentScores.insert(make_pair("Bob", 92));studentScores.insert(make_pair("Alice", 78));// 遍历输出学生成绩multimap<string, int>::iterator it;for (it = studentScores.begin(); it != studentScores.end(); ++it) {cout << "Name: " << it->first << ", Score: " << it->second << endl;}// 查找并输出某个学生的成绩string name = "Alice";pair<multimap<string, int>::iterator, multimap<string, int>::iterator> range;range = studentScores.equal_range(name);cout << name << "'s scores: ";for (it = range.first; it != range.second; ++it) {cout << it->second << " ";}cout << endl;return 0;
}

输出结果:

Name: Alice, Score: 85
Name: Alice, Score: 78
Name: Bob, Score: 92
Alice's scores: 85 78

 

结论

multimap是C++ STL中一个强大的容器,它可以存储多个值对应于同一个键的情况。通过了解multimap的特性和使用方法,我们可以更加灵活地处理具有重复键的数据,并提升程序的效率和可读性。

 

这篇关于c++ STL系列——(六)multimap的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/705757

相关文章

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

C++中NULL与nullptr的区别小结

《C++中NULL与nullptr的区别小结》本文介绍了C++编程中NULL与nullptr的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编... 目录C++98空值——NULLC++11空值——nullptr区别对比示例 C++98空值——NUL

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

C++11委托构造函数和继承构造函数的实现

《C++11委托构造函数和继承构造函数的实现》C++引入了委托构造函数和继承构造函数这两个重要的特性,本文主要介绍了C++11委托构造函数和继承构造函数的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、委托构造函数1.1 委托构造函数的定义与作用1.2 委托构造函数的语法1.3 委托构造函

C++11作用域枚举(Scoped Enums)的实现示例

《C++11作用域枚举(ScopedEnums)的实现示例》枚举类型是一种非常实用的工具,C++11标准引入了作用域枚举,也称为强类型枚举,本文主要介绍了C++11作用域枚举(ScopedEnums... 目录一、引言二、传统枚举类型的局限性2.1 命名空间污染2.2 整型提升问题2.3 类型转换问题三、C