「C/C++」C++ STL容器库 之 std::multiset 键的集合容器

在这里插入图片描述

✨博客主页
何曾参静谧的博客
📌文章专栏
「C/C++」C/C++程序设计
📚全部专栏
「VS」Visual Studio「C/C++」C/C++程序设计「UG/NX」BlockUI集合
「Win」Windows程序设计「DSA」数据结构与算法「UG/NX」NX二次开发
「QT」QT5程序设计「File」数据文件格式「PK」Parasolid函数说明

目录

    • std::multiset容器详解
      • 1. 引用头文件
      • 2. 注意事项
      • 3. 函数构造与对象初始化
      • 4. 元素访问
      • 5. 迭代器
      • 6. 容器修改器
      • 7. 元素比较
      • 总结与应用场景

std::multiset容器详解

1. 引用头文件

在使用std::multiset容器之前,需要包含相应的头文件<set>。std::multiset是C++标准模板库(STL)中的一种关联容器,用于存储有序的元素,并允许重复元素的存在。

#include <set>

2. 注意事项

  • std::multiset容器中的元素是有序的,根据元素的键值自动进行排序。
  • std::multiset允许存储重复的元素,这是与std::set的主要区别。
  • std::multiset中的元素不能直接修改,只能先删除原来的元素,然后插入新元素。
  • std::multiset的内部实现通常基于红黑树,因此元素的搜索、插入和删除操作都具有对数级的时间复杂度。

3. 函数构造与对象初始化

std::multiset提供了多种构造函数,可以创建空的容器,也可以使用初始化列表、其他容器的迭代器范围等进行初始化。

// 默认构造创建一个空的int类型的multiset
std::multiset<int> myMultiset; 
// 使用初始化列表创建multiset
std::multiset<std::string> myStringMultiset = {"apple", "banana", "orange"}; 
std::vector<int> vec = {1, 2, 2, 3, 4};
// 使用vector的元素初始化multiset
std::multiset<int> myMultisetFromVec(vec.begin(), vec.end()); 

4. 元素访问

在这里插入图片描述

std::multiset不支持使用下标位置直接访问元素,也不支持将元素插入到指定位置。但是可以使用find函数查找特定元素,使用count函数返回特定元素的数量。

std::multiset<int> myMultiset = {5, 10, 15, 20, 25, 20};
auto it = myMultiset.find(20);
if (it != myMultiset.end()) {
    std::cout << "Element found in multiset: " << *it << std::endl;
}
size_t count = myMultiset.count(20);
std::cout << "Count of 20: " << count << std::endl;

5. 迭代器

在这里插入图片描述

std::multiset提供了迭代器,用于遍历容器中的元素。迭代器支持前向遍历,也提供了反向迭代器(rbegin和rend),用于反向遍历。

std::multiset<int> myMultiset = {5, 10, 15, 20, 25, 20};
for (auto it = myMultiset.begin(); it != myMultiset.end(); ++it) {
    std::cout << *it << " ";
}
std::cout << std::endl;

for (auto it = myMultiset.rbegin(); it != myMultiset.rend(); ++it) {
    std::cout << *it << " ";
}
std::cout << std::endl;

6. 容器修改器

在这里插入图片描述

std::multiset提供了多种修改器函数,用于插入、删除和清空容器中的元素。

std::multiset<int> myMultiset = {5, 10, 15, 20, 25, 20};
myMultiset.insert(12); // 插入新元素
myMultiset.erase(15); // 删除指定元素
myMultiset.clear(); // 清空所有元素

7. 元素比较

在这里插入图片描述

std::multiset中的元素会根据指定的比较函数进行排序,默认是升序。可以通过指定比较函数来改变排序规则。

std::multiset<int, std::greater<int>> myMultisetDesc; // 创建一个降序排列的multiset
myMultisetDesc.insert(5);
myMultisetDesc.insert(10);
myMultisetDesc.insert(15);

for (auto it = myMultisetDesc.begin(); it != myMultisetDesc.end(); ++it) {
    std::cout << *it << " ";
}
std::cout << std::endl;

总结与应用场景

std::multiset是C++ STL中一个非常有用的容器,具有自动排序、允许重复元素以及快速插入和查找等特点。其内部实现基于红黑树,保证了高效的查找、插入和删除操作。std::multiset适用于需要维护元素顺序且需要存储重复元素的场景。

  • 需要存储有序且允许重复元素的集合。
  • 需要高效查找、插入和删除操作的场景。
  • 需要对元素进行排序和范围查询的场景。

例如,在处理学生成绩时,可以使用std::multiset来存储学生的分数,并方便地进行排序、查找和范围查询等操作。


在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

腾讯云跨AZ部署FortigateHA备忘录

随时保存配置 config system globalset admintimeout 480set alias "FortiGate-VM64-KVM"set gui-auto-upgrade-setup-warning disableset hostname "FG-Slave"set revision-backup-on-logout enableset revision-image-auto-backup enableset timezone &…

【 thinkphp8 】00006 启动 内、外置服务器

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 【 t…

Java学习Day53:铲除紫云山金丹原料厂厂长(手机快速登录、权限控制)

1.手机快速登录 手机快速登录功能&#xff0c;就是通过短信验证码的方式进行登录。这种方式相对于用户名密码登录方式&#xff0c;用户不需要记忆自己的密码&#xff0c;只需要通过输入手机号并获取验证码就可以完成登录&#xff0c;是目前比较流行的登录方式。 前端页面&…

centos7.x安装openCV 4.6.0版本

## 从源代码编译安装 1.更新系统 sudo yum update -y 2.安装依赖项 sudo yum groupinstall "Development Tools" sudo yum install cmake gcc-c git libjpeg-turbo-devel libpng-devel libtiff-devel libwebp-devel openexr-devel gstreamer1-plugins-base-devel…

iTerm2 保持SSH远程连接

1、保持SSH远程连接的稳定&#xff0c;防止因闲置时间过长而断开连接 When idle, send ASCII code 35 every 60 seconds每60秒 输入# 2、客户端设置保持活动 设置客户端每隔60秒发送一次保活信号&#xff0c;总共尝试3次。 vim ~/.ssh/configHost *ServerAliveInterval 60…

uniapp 底部导航栏tabBar设置后不显示的问题——已解决

uniapp 底部导航栏tabBar设置后不显示的问题——已解决 网上找了一堆解决办法&#xff0c;挨个对着试吧 解决办法一&#xff1a;tabBar里的list第一项和page中的第一项要相同&#xff0c;确实就能显示了。但是问题来了&#xff0c;page中的第一项是入口页&#xff0c;那就意味…

鲸鱼优化算法(Whale Optimization Algorithm, WOA)原理与MATLAB例程

鲸鱼优化算法&#xff08;Whale Optimization Algorithm, WOA&#xff09;是一种基于鲸鱼捕食行为的智能优化算法。它模拟了座头鲸在狩猎时的“气泡网”捕食策略。 文章目录 1.适应度函数2. 更新公式2.1 突袭行为2.2 螺旋更新3.线性递减参数4. 边界处理 MATLAB 实现示例代码说明…

HarmonyOS 5.0应用开发——Navigation实现页面路由

【高心星出品】 文章目录 Navigation实现页面路由完整的Navigation入口页面子页面 页面跳转路由拦截其他的 Navigation实现页面路由 Navigation&#xff1a;路由导航的根视图容器&#xff0c;一般作为页面&#xff08;Entry&#xff09;的根容器去使用&#xff0c;包括单页面&…

前端构建工具vite的优势

1. 极速冷启动 Vite 使用原生 ES 模块 (ESM) 在开发环境下进行工作。相比于传统构建工具需要打包所有的文件&#xff0c;Vite 只在浏览器请求模块时动态加载所需的文件。无打包冷启动&#xff1a;无需预先打包&#xff0c;项目启动非常快&#xff0c;尤其对于大型项目效果更明…

Arduino Uno 同时控制多路舵机

Arduino Uno同时控制4个舵机 舵机可以在0~180度内指定角度的控制。常用于航模、机器人、遥控玩具等物品,然而,很多时候要一次性控制多个舵机,今天以控制4个舵机为例进行说明 接线方式如下图: 舵机的信号线分别接A0,A1,A2,A3。控制舵机从0旋转到180度,再由180度旋转到0度,…

基于NERF技术重建学习笔记

NeRF&#xff08;Neural Radiance Fields&#xff09;是一种用于3D场景重建的神经网络模型&#xff0c;能够从2D图像生成逼真的3D渲染效果。它将场景表征为一个连续的5D函数&#xff0c;利用了体积渲染和神经网络的结合&#xff0c;通过学习光线穿过空间时的颜色和密度来重建场…

机器视觉-相机、镜头、光源(总结)

目录 1、机器视觉光源概述 2、光源的作用 3、光谱 4、工业场景常见光源 4.1、白炽灯 4.2、卤素灯 4.3、 荧光灯 4.4、LED灯 4.5、激光灯 5、光源的基本性能 5.1、光通量 5.2、光效率 5.3、发光强度 5.4、光照度 5.5、均匀性 5.6、色温 5.7、显色性 6、基本光学…

openpnp - 解决“底部相机高级校正成功后, 开机归零时,吸嘴自动校验失败的问题“

文章目录 openpnp - 解决"底部相机高级校正成功后, 开机归零时&#xff0c;吸嘴自动校验失败的问题"概述笔记问题现象1问题现象2原因分析现在底部相机和吸嘴的位置偏差记录修正底部相机位置现在再看看NT1在底部相机中的位置开机归零&#xff0c;看看是否能通过所有校…

python csv库

python csv库 水一水又是一篇&#xff0c;乐 读取 import csv # 打开 CSV 文件 with open(example.csv, moder, newline) as file: csv_reader csv.reader(file) # 读取文件头&#xff08;可选&#xff09; headers next(csv_reader) print(f"Headers: {heade…

golang将指针传给cgo后还能被回收吗?

问题&#xff1a; 如果把golang分配的变量&#xff0c;其指针通过cgo传给c&#xff0c;并被c存储&#xff0c;那这个变量还能被gc回收吗&#xff1f; 实验代码&#xff1a; test_memory_leak.go package main/* #include <stdlib.h> #include <string.h> #incl…

基于docker-compose编排部署微服务快速开发框架

1. 规划节点 节点规划&#xff0c;见表1。 表1 节点规划 IP主机名节点10.24.2.10masterdocker-compose节点 2. 基础准备 Docker和Docker Compose已安装完成&#xff0c;将提供的软件包Pig.tar.gz上传至master节点/root目录下并解压。 案例实施 1. 基础环境准备 &#x…

渗透测试-百日筑基—SQL注入篇时间注入绕过HTTP数据编码绕过—下

day8-渗透测试sql注入篇&时间注入&绕过&HTTP数据编码绕过 一、时间注入 SQL注入时间注入&#xff08;也称为延时注入&#xff09;是SQL注入攻击的一种特殊形式&#xff0c;它属于盲注&#xff08;Blind SQL Injection&#xff09;的一种。在盲注中&#xff0c;攻击…

模型评估:Accuracy、Precision、Recall、F1、ROC曲线、AUC、PR曲线

Accuracy & Precision & Recall & F1 准确率 Accuracy A c c u r a c y T T T F A L L Accuracy \frac{TT TF}{ALL} AccuracyALLTTTF​ 1.分类器到底分对了多少&#xff1f; 精确率 Precision 2.返回的图片中正确的有多少&#xff1f; 召回率 / 查全率 …

了解光耦合器输入输出关系---腾恩科技

光耦合器&#xff0c;也称为光隔离器&#xff0c;是电子电路中必不可少的元件&#xff0c;主要用于在隔离部分之间传输信号&#xff0c;同时防止电噪声或高压影响敏感元件。其独特的设计使它们能够在没有直接电接触的情况下&#xff0c;弥合不同电压域之间的差距。在本文中&…

解决docker拉取readeck镜像报Error response from daemon: toomanyrequests问题

readeck 是一个内容中心&#xff0c;目前已支持中文翻译 这是本地化部署后的效果&#xff1a; 原命令为&#xff1a; docker run --rm -ti -p 8000:8000 -v readeck-data:/readeck codeberg.org/readeck/readeck:latest Unable to find image codeberg.org/readeck/readeck:la…