当前位置: 首页 > news >正文

c++ set/multiset 容器

1. set 基本概念

简介:

所有元素都会在插入时自动排序

本质:

set/multiset属于关联式容器,底层结构是用二叉树实现。

set 和 multiset 区别:

set容器不允许有重复的元素。
multiset允许有重复的元素。

2. set 构造和赋值

构造:

set<T> st; // 默认构造函数
set<T> st(const T& x); // 将x拷贝到st中

赋值:

set& operator=(const set& st); // 将st赋值给当前set	
#include <iostream>
#include <fstream>
#include <string>
#include <set>
using namespace std;//set 构造和赋值void printSet(const set<int>& s){for(set<int>::iterator it = s.begin(); it != s.end(); it++){cout << *it << " ";}cout << endl;
}void test01() {set<int> s1;// 插入数据只有insert一种方式s1.insert(10); // 插入元素s1.insert(30);s1.insert(60);s1.insert(20);s1.insert(20);// set容器的特点:所有元素都会在插入时自动被排序// set容器不允许插入重复数据printSet(s1);// 拷贝构造set<int> s2(s1);printSet(s2);// 赋值set<int> s3;s3 = s1;printSet(s3);
}int main(int argc, char const *argv[]) {test01();return 0;
}

3. set 大小和交换

功能描述:

统计set容器大小以及交换set 容器

函数原型

size(); // 返回set中元素的个数
empty(); // 判断set是否为空
swap(set<T> &s); // 交换sets
#include <iostream>
#include <fstream>
#include <string>
#include <set>
using namespace std;//set 大小和交换void printSet(const set<int>& s){for(set<int>::iterator it = s.begin(); it != s.end(); it++){cout << *it << " ";}cout << endl;
}// 大小
void test01() {set<int> s;s.insert(20);s.insert(10);s.insert(30);s.insert(40);printSet(s);// 判断是否为空if(s.empty()) {cout << "s is empty" << endl;}else{cout << "s is not empty" << endl;}cout << "s.size() = " << s.size() << endl;}// 交换
void test02() {set<int> s;s.insert(20);s.insert(10);s.insert(30);s.insert(40);set<int> s2;s2.insert(100);s2.insert(200);s2.insert(300);cout << "交换前:" << endl;printSet(s);printSet(s2);cout << "交换后:" << endl;s.swap(s2);printSet(s);printSet(s2);}int main(int argc, char const *argv[]) {test02();return 0;
}

4. set插入和删除操作

函数原型

void insert(const value_type& val); // 插入元素
clear(); // 清除所有元素
erase(iterator pos); // 删除pos位置的元素,返回下一个元素的迭代器
erase(iterator start, iterator end); // 删除从start到end之间的元素,返回下一个元素的迭代器
erase(const value_type& val); // 删除值为val元素,返回删除元素的个数
#include <iostream>
#include <fstream>
#include <string>
#include <set>
using namespace std;// set插入和删除操作void printSet(const set<int>& s){for(set<int>::iterator it = s.begin(); it != s.end(); it++){cout << *it << " ";}cout << endl;
}// 大小
void test01() {set<int> s;s.insert(20);s.insert(10);s.insert(30);s.insert(40);s.insert(50);s.insert(100);printSet(s);s.erase(s.begin());printSet(s);s.erase(++s.begin(), --s.end());printSet(s);s.erase(20);printSet(s);cout << "清空集合" << endl;s.clear();printSet(s);}int main(int argc, char const *argv[]) {test01();return 0;
}

5 set 查找和统计

函数原型:

find(const key_type& key); // 查找key是否存在,若存在,返回该元素的迭代器;若不存在,返回结束迭代器end()
count(const key_type& key); // 统计key的个数
#include <iostream>
#include <fstream>
#include <string>
#include <set>
using namespace std;// set 查找和统计
// 函数原型:// find(const key_type& key); // 查找key是否存在,若存在,返回该元素的迭代器;若不存在,返回结束迭代器end()
// count(const key_type& key); // 统计key的个数void printSet(const set<int>& s){for(set<int>::iterator it = s.begin(); it != s.end(); it++){cout << *it << " ";}cout << endl;
}// 大小
void test01() {set<int> s;s.insert(20);s.insert(10);s.insert(30);s.insert(40);s.insert(50);s.insert(100);set<int>::iterator it = s.find(50);if(it == s.end()){cout << "找不到" << endl;}else{cout << "找到了 " <<*it<< endl;}// 统计key的个数, 找到返回1,找不到返回0int count = s.count(10);cout << "count = " << count << endl;}int main(int argc, char const *argv[]) {test01();return 0;
}

6 set 和 multiset的区别

区别:

set不可以插入重复数据,而multiset可以
set插入数据同时会返回插入结果,表示插入是否成功
multiset 不会检测数据,因此可以插入重复数据
#include <iostream>
#include <fstream>
#include <string>
#include <set>
using namespace std;// set 和 multiset的区别void printSet(const set<int>& s){for(set<int>::iterator it = s.begin(); it != s.end(); it++){cout << *it << " ";}cout << endl;
}// 大小
void test01() {set<int> s;pair<set<int>::iterator,bool> ret =  s.insert(20);if(ret.second == true){cout << "第一次插入成功" << endl;}else{cout << "第一次插入失败" << endl;}ret = s.insert(20);if(ret.second == true){cout << "第二次插入成功" << endl;}else{cout << "第二次插入失败" << endl;}multiset<int> ms;// 允许重复插入ms.insert(20);ms.insert(20);ms.insert(20);ms.insert(20);ms.insert(20);for(multiset<int>::iterator it = ms.begin(); it != ms.end(); it++){cout << *it << " ";}cout << endl;
}int main(int argc, char const *argv[]) {test01();return 0;
}

7 pair对组创建

功能描述:

成对出现的数据,利用对组可以返回两个数据

两种创建方式:

pair<int,int> p(value1,value2); // 创建一个pair对组,value1和value2分别对应pair的两个元素
pair<int,int> p = make_pair(value1,value2); // 创建一个pair对组,value1和value2分别对应pair的两个元素
#include <iostream>
#include <fstream>
#include <string>
#include <set>
using namespace std;// pair对组创建// 大小
void test01() {// 第一种创建方式pair<string, int> p1("西施", 20);cout << p1.first << " " << p1.second << endl;// 第二种创建方式pair<string, int> p2 = make_pair("貂蝉", 18);cout << p2.first << " " << p2.second << endl;}int main(int argc, char const *argv[]) {test01();return 0;
}

8 set 容器排序

目标:

set容器默认排序规制为从小到大,掌握如何改变排序规则

主要技术点:

利用防函数,可以改变排序规则
#include <iostream>
#include <fstream>
#include <string>
#include <set>
using namespace std;// set 容器排序void printSet(set<int> &s) {for(set<int>::iterator it = s.begin(); it != s.end(); it++) {cout << *it << " ";}cout << endl;
}class MyCompare {
public:bool operator()(int a,int b) const{// 比较逻辑return a > b;}
};// 
void test01() {set<int> s;s.insert(10);s.insert(30);s.insert(20);s.insert(40);s.insert(50);printSet(s);//指定排序规制,从大到小set<int,MyCompare> s2;s2.insert(10);s2.insert(30);s2.insert(20);s2.insert(40);s2.insert(50);for(set<int,MyCompare>::iterator it = s2.begin(); it != s2.end(); it++) {cout << *it << " ";}cout << endl;
}int main(int argc, char const *argv[]) {test01();return 0;
}
#include <iostream>
#include <fstream>
#include <string>
#include <set>
using namespace std;// set 容器排序
class Person {public:Person(string name, int age) {this->age = age;this->name = name;}string name;int age;
};class MyCompare {
public:// const 不能省bool operator()(const Person& a, const Person& b) const{// 比较逻辑return a.age < b.age;}
};void printSet(set<Person,MyCompare> &s) {for(set<Person,MyCompare>::iterator it = s.begin(); it != s.end(); it++) {cout << "name: " << it->name << " age: " << it->age << endl;}cout << endl;
}void test01() {//自定义数据类型,必须要指定排序规则set<Person, MyCompare> s;s.insert(Person("西施", 18));s.insert(Person("王昭君", 19));s.insert(Person("杨玉环", 17));s.insert(Person("貂蝉", 16));printSet(s);}int main(int argc, char const *argv[]) {test01();return 0;
}

相关文章:

c++ set/multiset 容器

1. set 基本概念 简介&#xff1a; 所有元素都会在插入时自动排序本质&#xff1a; set/multiset属于关联式容器&#xff0c;底层结构是用二叉树实现。set 和 multiset 区别&#xff1a; set容器不允许有重复的元素。 multiset允许有重复的元素。2. set 构造和赋值 构造&a…...

前部分知识复习02

一、物体的屏幕UV坐标 float2 ScreenUV i.pos.xy / _ScreenParams.xy; 二、抓取屏幕图像 GrabPass{" _A "} //_A为贴图图像名称 之后需在Pass中声明该贴图才能在Pass中引用此贴图 三、屏幕抓取并制作热效应代码 Shader"unity/HeatDistort 07" {Pr…...

开发环境搭建-3:配置 JavaScript 开发环境 (fnm+ nodejs + pnpm + nrm)

在 WSL 环境中配置&#xff1a;WSL2 (2.3.26.0) Oracle Linux 8.7 官方镜像 node 官网&#xff1a;https://nodejs.org/zh-cn/download 点击【下载】&#xff0c;选择想要的 node 版本、操作系统、node 版本管理器、npm包管理器 根据下面代码提示依次执行对应代码即可 基本概…...

kotlin内联函数——let,run,apply,also,with的区别

一、概述 为了帮助您根据使用场景选择合适的作用域函数&#xff08;scope function&#xff09;&#xff0c;我们将对它们进行详细描述并提供使用建议。从技术上讲&#xff0c;许多情况下范围函数是可以互换使用的&#xff0c;因此示例中展示了使用它们的约定俗成的做法。 1.…...

【深度学习|DenseNet-121】Densely Connected Convolutional Networks内部结构和参数设置

【深度学习|DenseNet-121】Densely Connected Convolutional Networks内部结构和参数设置 【深度学习|DenseNet-121】Densely Connected Convolutional Networks内部结构和参数设置 文章目录 【深度学习|DenseNet-121】Densely Connected Convolutional Networks内部结构和参数…...

数据结构与算法-要点整理

知识导图: 一、数据结构 包含:线性表(数组、队列、链表、栈)、散列表、树(二叉树、多路查找树)、图 1.线性表 数据之间就是“一对一“的逻辑关系。 线性表存储数据的实现方案有两种,分别是顺序存储结构和链式存储结构。 包含:数组、队列、链表、栈。 1.1 数组…...

Fort Firewall:全方位守护网络安全

Fort Firewall是一款专为 Windows 操作系统设计的开源防火墙工具&#xff0c;旨在为用户提供全面的网络安全保护。它基于 Windows 过滤平台&#xff08;WFP&#xff09;&#xff0c;能够与系统无缝集成&#xff0c;确保高效的网络流量管理和安全防护。该软件支持实时监控网络流…...

Nginx实战技巧(Practical Tips for nginx)

引言 简介 ‌Nginx&#xff08;发音为 "engine-x"&#xff09;是一个高性能的HTTP和反向代理服务器.‌ Nginx以其高并发处理能力、低资源消耗和灵活的配置而闻名&#xff0c;适用于高流量的Web服务器和应用程序。‌ Nginx的主要功能包括&#xff1a; ‌HTTP服务器…...

YOLOv8:目标检测与实时应用的前沿探索

随着深度学习和计算机视觉技术的迅速发展&#xff0c;目标检测&#xff08;Object Detection&#xff09;一直是研究热点。YOLO&#xff08;You Only Look Once&#xff09;系列模型作为业界广受关注的目标检测框架&#xff0c;凭借其高效、实时的特点&#xff0c;一直迭代更新…...

解锁数字经济新动能:探寻 Web3 核心价值

随着科技的快速发展&#xff0c;我们正迈入一个全新的数字时代&#xff0c;Web3作为这一时代的核心构成之一&#xff0c;正在为全球数字经济带来革命性的变革。本文将探讨Web3的核心价值&#xff0c;并如何推动数字经济的新动能。 Web3是什么&#xff1f; Web3&#xff0c;通常…...

Lua 环境的安装

1.安装Lua运行环境 本人采用的是在windows系统中使用cmd指令方式进行安装&#xff0c;安装指令如下&#xff1a; winget install "lua for windows" 也曾使用可执行程序安装过&#xff0c;但由于电脑是加密电脑&#xff0c;最后都已失败告终。使用此方式安装可以安…...

Object类(2)

大家好&#xff0c;今天我们继续来看看Object类中一些成员方法&#xff0c;这些方法在实际中有很大的用处&#xff0c;话不多说&#xff0c;来看。 注&#xff1a;所有类都默认继承Object类的&#xff0c;所以可调用Object类中的方法&#xff0c;如equals&#xff0c;也可以发生…...

汽车网络信息安全-ISO/SAE 21434解析(中)

目录 第七章-分布式网络安全活动 1. 供应商能力评估 2. 报价 3. 网络安全职责界定 第八章-持续的网络安全活动 1. 网路安全监控 2. 网络安全事件评估 3. 漏洞分析 4. 漏洞管理 第九章-概念阶段 1. 对象定义 2. 网路安全目标 3. 网络安全概念 第十章 - 产品开发 第十…...

fatal error C1083: ޷[特殊字符]ļ: openssl/opensslv.h: No such file or directory

一、环境 1. Visual Studio 2017 2. edk2&#xff1a;202305 3. Python&#xff1a;3.11.4 二、 fatal error C1083: ޷&#xbfab0;ļ: openssl/opensslv.h: No such file or directory 上图出现这个警告&#xff0c;不用管。 出现Done&#xff0c;说明编译成功。 执行上…...

C#System.Threading.Timer定时器意外回收注意事项

System.Threading.Timer定时器使用时会出现意外回收的情况。具体解释如下: 只要在使用 Timer,就必须保留对它的引用。对于任何托管对象,如果没有对 Timer 的引用,计时器会被垃圾回收。即使 Timer 仍处在活动状态,也会被回收。 实例对比测试 实例 定义两个类,其中一个…...

20.Word:小谢-病毒知识的科普文章❗【38】

目录 题目​ NO1.2.3文档格式 NO4.5 NO6.7目录/图表目录/书目 NO8.9.10 NO11索引 NO12.13.14 每一步操作完&#xff0c;确定之后记得保存最后所有操作完记得再次删除空行 题目 NO1.2.3文档格式 样式的应用 选中应用段落段落→开始→选择→→检查→应用一个一个应用ctr…...

vue3底层原理和性能优化

Vue 3 在底层原理和性能优化方面做了许多改进&#xff0c;以下是一些主要的优化点和原理&#xff1a; 1. 虚拟 DOM 的改进 静态树提升&#xff1a;Vue 3 能够检测到静态组件&#xff08;即不依赖响应式数据的组件&#xff09;并将其提升到渲染函数之外&#xff0c;从而减少不…...

Ubuntu介绍、与centos的区别、基于VMware安装Ubuntu Server 22.04、配置远程连接、安装jdk+Tomcat

目录 ?编辑 一、Ubuntu22.04介绍 二、Ubuntu与Centos的区别 三、基于VMware安装Ubuntu Server 22.04 下载 VMware安装 1.创建新的虚拟机 2.选择类型配置 3.虚拟机硬件兼容性 4.安装客户机操作系统 5.选择客户机操作系统 6.命名虚拟机 7.处理器配置 8.虚拟机内存…...

金融级分布式数据库如何优化?PawSQL发布OceanBase专项调优指南

前言 OceanBase数据库作为国产自主可控的分布式数据库&#xff0c;在金融、电商、政务等领域得到广泛应用&#xff0c;优化OceanBase数据库的查询性能变得愈发重要。PawSQL为OceanBase数据库提供了全方位的SQL性能优化支持&#xff0c;助力用户充分发挥OceanBase数据库的性能潜…...

springboot 动态线程池

在Spring Boot中&#xff0c;可以使用ThreadPoolTaskExecutor类来创建动态线程池。以下是一个示例&#xff1a; 首先&#xff0c;需要在配置文件中配置线程池的属性&#xff0c;例如最小线程数、最大线程数、线程存活时间等。可以在application.properties或application.yml中…...

新手入门:零基础借助快马生成你的第一个openmaic网页版调用程序

今天想和大家分享一个特别适合新手入门的实践项目——如何借助InsCode(快马)平台快速生成你的第一个openmaic网页版调用程序。作为一个刚接触AI开发的新手&#xff0c;我最初看到各种API文档和代码示例时也是一头雾水&#xff0c;但通过这个可视化工具&#xff0c;居然半小时就…...

终极指南:30分钟打造你的首个ESP32 AI智能硬件项目

终极指南&#xff1a;30分钟打造你的首个ESP32 AI智能硬件项目 【免费下载链接】xiaozhi-esp32 An MCP-based chatbot | 一个基于MCP的聊天机器人 项目地址: https://gitcode.com/GitHub_Trending/xia/xiaozhi-esp32 还在为嵌入式AI开发的高门槛而烦恼吗&#xff1f;物联…...

GNU Radio滤波器设计实战指南:从原理到高性能实现

GNU Radio滤波器设计实战指南&#xff1a;从原理到高性能实现 【免费下载链接】gnuradio GNU Radio – the Free and Open Software Radio Ecosystem 项目地址: https://gitcode.com/gh_mirrors/gn/gnuradio GNU Radio作为开源软件定义无线电生态系统&#xff0c;提供了…...

效率飙升,跳过proteus安装配置,用快马ai秒建仿真项目

最近在做一个温度监测系统的项目&#xff0c;需要验证电路设计的可行性。按照传统方式&#xff0c;我得先下载安装Proteus软件&#xff0c;配置各种库文件&#xff0c;光是环境准备就得折腾半天。不过这次尝试了用InsCode(快马)平台的AI功能&#xff0c;整个过程变得异常高效。…...

攻克ComfyUI ControlNet Aux预处理难题:4个实用方案助你快速恢复功能

攻克ComfyUI ControlNet Aux预处理难题&#xff1a;4个实用方案助你快速恢复功能 【免费下载链接】comfyui_controlnet_aux ComfyUIs ControlNet Auxiliary Preprocessors 项目地址: https://gitcode.com/gh_mirrors/co/comfyui_controlnet_aux ComfyUI ControlNet Auxi…...

融智学三大基本定律——信息世界的根本法则体系:为跨模态知识处理、人机协同等前沿领域提供原理支撑

融智学三大基本定律——信息世界的根本法则体系摘要&#xff1a;融智学三大基本定律构成信息处理的核心理论体系。第一定律&#xff08;实部序位关系唯一守恒&#xff09;确立本质信息的稳定性&#xff1b;第二定律&#xff08;实部序位同义并列对应转换&#xff09;实现多元表…...

从 14 万美元支付事故看:AI 写的代码过了所有测试,为什么活不过生产?

我审计过的一家科技公司&#xff0c;曾因一段 AI 生成的异步支付处理代码&#xff0c;遭遇了一场灾难性的生产事故。这段代码完美通过了所有自动化检查、单元测试与集成测试&#xff0c;标注着「All checks passed」被顺利合并到生产环境&#xff0c;最终却触发了竞态条件与重复…...

Pixel Epic智识终端效果展示:跨领域研报生成一致性与专业性验证

Pixel Epic智识终端效果展示&#xff1a;跨领域研报生成一致性与专业性验证 1. 产品概览与核心价值 Pixel Epic智识终端是一款基于AgentCPM-Report大模型构建的专业研究报告生成工具。与传统AI工具不同&#xff0c;它创新性地采用了像素RPG游戏的美学设计&#xff0c;将枯燥的…...

PID控制在自动循迹小车中的实战应用与参数整定指南

PID控制在自动循迹小车中的实战应用与参数整定指南 当你在实验室里第一次看到自己设计的自动循迹小车歪歪扭扭地沿着黑线前进时&#xff0c;那种既兴奋又挫败的感觉一定记忆犹新。为什么理论上完美的PID算法&#xff0c;在实际应用中却总是出现超调、振荡或者响应迟缓&#xff…...

从NTLM中继到域控接管:ADCS-ESC8漏洞实战解析

1. ADCS-ESC8漏洞概述 ADCS-ESC8是Active Directory证书服务(AD CS)中的一个高危漏洞&#xff0c;它允许攻击者通过NTLM中继攻击获取域控制器证书。这个漏洞的核心在于ADCS默认配置中的Web证书注册页面仅使用HTTP协议且支持NTLM认证&#xff0c;但未启用任何中继攻击防护措施。…...