STL - Set容器

news2024/11/24 3:07:21

基本概念

 构造和赋值

功能描述:创建set容器以及赋值

#include <algorithm> //算法
#include <iostream>
#include <set>
#include <string>
using namespace std;

// set/multiset容器

void printSet(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(5);
    s1.insert(2);
    s1.insert(20);
//    s1.insert(5); //不允许插入重复的值
    //插入的时候会自动排序
    printSet(s1);
    
    set<int>s2(s1);
    
    printSet(s2);
    //赋值
    set<int>s3 = s2;
    
}
int main()
{
    test01();
}

 

set大小和交换

 

#include <algorithm> //算法
#include <iostream>
#include <set>
#include <string>
using namespace std;

// set/multiset容器

void printSet(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(5);
    s1.insert(2);
    s1.insert(20);
    printSet(s1);

    //判断为空
    if (!s1.empty()) {
        cout << s1.size()<<endl;
    } else {
        cout << "为空" << endl;
    }
}
int main()
{
    test01();
}

 set插入和删除

功能描述:
        set容器的插入和删除数据

#include <algorithm> //算法
#include <iostream>
#include <set>
#include <string>
using namespace std;

// set/multiset容器

void printSet(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(5);
    s1.insert(2);
    s1.insert(20);
    printSet(s1); // 2 5 10 20

    //删除
    s1.erase(20); //删除2数据
    //    s1.erase(s1.begin());
    set<int>::iterator it = s1.erase(s1.begin()); //一起删,数据会错误 ,删除后返回迭代器
    cout << "返回的迭代器" << *it << endl; // 10 返回原先迭代器下一个元素的迭代器
    printSet(s1);

    s1.clear(); //清空
    printSet(s1);
}
int main()
{
    test01();
}

 查找和统计

功能描述:
        对set容器进行查找数据和统计数据

#include <algorithm> //算法
#include <iostream>
#include <set>
#include <string>
using namespace std;

// set/multiset容器

void printSet(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(5);
    s1.insert(3);
    s1.insert(20);
    s1.insert(50);

    printSet(s1); // 2 5 10 20
    cout << "set容器的个数" << s1.size() << endl;
    //查找,统计
    set<int>::iterator pos = s1.find(1); //找到返回元素,找不到返回元素个数
    cout << *pos << endl;
    if (pos != s1.end()) {
        cout << "找到元素" << endl;
    } else {
        cout << "未找到元素" << endl;
    }

    set<int>::iterator be = s1.begin();
    cout << "迭代器开头" << *be << endl; // 3  开头元素
    be = s1.end();
    cout << "迭代器结尾" << *be << endl; // 4  end(),指向的是最后一个元素的后一个下标,结尾解引用为元素大小

    //统计个数
    int num = s1.count(3);
    cout << "容器中3出现的个数" << num << endl;
}
int main()
{
    test01();
}

 set和multiset区别

学习目标:
        掌握set和multiset区别。

#include <algorithm> //算法
#include <iostream>
#include <set>
#include <string>
using namespace std;

// set/multiset容器

void printSet(set<int>& s)
{
    for (set<int>::iterator it = s.begin(); it != s.end(); it++) {
        cout << *it << " ";
    }
    cout << endl;
}
void printMultiset(multiset<int>& s)
{
    for (multiset<int>::iterator it = s.begin(); it != s.end(); it++) {
        cout << *it << " ";
    }
    cout << endl;
}
void test01()
{
    set<int> s1;
    //插入数据只有insert
    s1.insert(10);
    s1.insert(5);
    s1.insert(3);
    s1.insert(20);
    pair<set<int>::iterator, bool> ret = s1.insert(3); //返回一个pair模板
    printSet(s1); // 2 5 10 20

    if (ret.second) { //如果第二个为真,
        cout << *ret.first << endl; //获取第一个数据
    } else {
        cout << "插入失败" << endl;
    }
}
void test02()
{

    multiset<int> ms;
    //允许插入重复的值
    ms.insert(10);
    ms.insert(1);
    ms.insert(10);
    printMultiset(ms);
    
}

int main()
{
    test02();
}

 pair使用

#include <algorithm> //算法
#include <iostream>
#include <string>

using namespace std;

// pair队组

void printPair(pair<int, int>& p)
{
    cout << p.first << endl;
    cout << p.second << endl;
}

void test02()
{
    pair<int, int> p(1, 10);
    printPair(p);
    //第二种方式
    pair<string, int> p2 = make_pair(string("test"), 1);
    
    printPair(p2);
    
}

int main()
{
    test02();
}

set容器排序

示例一:set存放内置的数据类型

#include <algorithm> //算法
#include <iostream>
#include <set>
#include <string>

using namespace std;

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 v1, int v2) const //需要加const进行修饰,不可以改变
    {
        return v1 > v2; //大于返回真
    }
};
void test02()
{
    set<int> s;
    s.insert(1);
    s.insert(5);
    s.insert(0);
    s.insert(30);

    printSet(s);
    //指定规则为从小到大
    //    插入数据前告诉他
    set<int, MyCompare> s1; //仿函数
    s1.insert(1);
    s1.insert(5);
    s1.insert(0);
    s1.insert(30);
    for (set<int, MyCompare>::iterator it = s1.begin(); it != s1.end(); it++) {
        cout << *it << " ";
    }
    cout << endl;
}

int main()
{
    test02();
}

 总结:利用仿函数可以指定set容器的排序规则。

示例二:set存放自定义的数据类型

#include <algorithm> //算法
#include <iostream>
#include <set>
#include <string>

using namespace std;

class Person {
public:
    string m_Name;
    int m_Age;
    Person(string name, int age)
    {
        this->m_Age = age;
        this->m_Name = name;
    }
};
class MyCompare {
public:
    //比较对象必须作为常量可调用。
    bool operator()(const Person& p1, const Person& p2) const //因为要对比数据,数据内部需要加const进行限定
    {
        return p1.m_Age > p2.m_Age;
    }
};
void test02()
{
    set<Person, MyCompare> s;
    Person p1("张三", 13);
    Person p2("李四", 10);
    Person p3("王五", 10); //因为是set不允许重复操作
    Person p4("赵六", 1);
    s.insert(p1);
    s.insert(p2);
    s.insert(p3);
    s.insert(p4);

    for (set<Person, MyCompare>::iterator it = s.begin(); it != s.end(); it++) {
        cout << it->m_Name << " " << it->m_Age;
    }
    cout << endl;
}

int main()
{
    test02();
}

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

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

相关文章

Java之节点流和处理流(Buffered字节字符处理流)

文章目录前言基本介绍Buffered字符处理流BufferedReader缓冲字符输入流BufferedWriter缓冲字符输出流文件拷贝Buffered字节处理流文件拷贝&#xff08;二进制文件&#xff09;处理流关闭问题前言 Java中的流按照功能可以分为节点流和处理流。其中节点流是直接用来访问数据源&a…

GO的interface的使用和反射

博客主页&#xff1a;&#x1f3c6;看看是李XX还是李歘歘 &#x1f3c6; &#x1f33a;每天不定期分享一些包括但不限于计算机基础、算法、后端开发相关的知识点&#xff0c;以及职场小菜鸡的生活。&#x1f33a; &#x1f497;点关注不迷路&#xff0c;总有一些&#x1f4d6;知…

自动化测试

一、关于自动化什么是自动化?扫地机器人 自动浇水机 自动洗手液 智能马桶... &#xff0c;能够有效的减少人力的消耗&#xff0c;同时提高生活质量。而自动化测试同样&#xff0c;能够有效减少人力的投入&#xff0c;同时提高了测试的质量和效率。回归测试&#xff0c;版本越来…

23.Isaac教程--Isaac导航

Isaac导航 ISAAC教程合集地址: https://blog.csdn.net/kunhe0512/category_12163211.html 节点和消息 Isaac 应用程序由多个节点创建。 导航堆栈具有以下节点&#xff1a; GlobalLocalization&#xff1a;在没有先验信息的情况下&#xff0c;仅使用当前范围扫描测量来估计地…

【JavaGuide面试总结】MySQL篇·上

【JavaGuide面试总结】MySQL篇上1.SQL语句在MySQL中的执行过程MySQL架构Server 层基本组件介绍查询语句分析更新语句分析总结2.MySQL更新语句为什么要用两个日志模块&#xff0c;用一个日志模块不行吗?3.MySQL 支持哪些存储引擎&#xff1f;默认使用哪个&#xff1f;4.MySQL 存…

虹科分享 | TSN时间敏感网络测试框架

一、时间敏感网络 时间敏感网络&#xff08;TSN&#xff09;允许合并OT和IT世界&#xff0c;并保证确定性以太网网络中所有设备的互操作性和标准化。TSN建立在一个真正成熟的生态系统中&#xff08;如以太网&#xff09;&#xff0c;因此大家认为TSN将是下一代工业网络通信的核…

top命令详解

1. 命令参数 d : 监控内容刷新的时间间隔。 n : 限定监控内容刷新的次数&#xff0c;完成后将会退出 top 视图。 p : 只监控指定PID的进程。 -b : 以非交互非全屏模式运行&#xff0c;一般配合-n指定输出几次统计信息&#xff0c;将输出重定向到指定文件&#xff0c;比如 top …

二分查找----C/C++

目录 1. 二分查找的概念 2. 整数的二分 2.1 二分的模版一 2.2 二分的模版二 2.3. 案例剖析 2.4.整数二分总结 3. 浮点数的二分 1. 二分查找的概念 折半查找(BinarySearch)技术&#xff0c;又称为二分查找。它的前提是线性表中的记录 必须是关键码有序(通常从小到大有序)&a…

mysql 分库分表、 分区(partition)、sharding-sphere 综合整理

引言&#xff1a; 一般情况下&#xff0c;如果单表数据量超过2000w的样子查询速度会很慢&#xff0c;因为内存无法存储其索引&#xff0c;使得之后的 SQL 查询会产生磁盘 IO&#xff0c;从而导致性能下降。解决方案&#xff1a;mysql 分区 、 分表处理 分库分表&#xff1a; 原…

【匠心打造】从0打造uniapp 可视化拖拽设计 c_o 第六篇

1、这个版本的变化是左侧增加了布局设计和包资源管理器 包资源管理器&#xff1a;eclipse的特称&#xff0c;左侧的项目管理。和hbuildx左侧类似 项目的整体设计结构如下: v1.0 普通模式&#xff1a;支持新建前端项目&#xff0c;拖拽&#xff0c;且生成前端项目&#xff08…

基于“遥感+”蓝碳储量估算、红树林信息提取实践技术应用与科研论文写作

目录 “遥感”助推蓝碳生态系统碳储量调查简介 第一章 高光谱遥感数据介绍及预处理 第二章 光谱特征分析与参量提取 第三章 高光谱遥感数据分类与制图 第四章 GEE数据处理介绍 第五章 碳储量时空变化与预测 大气温室气体浓度不断增加&#xff0c;导致气候变暖加剧&#x…

DFS的树上应用

目录 一、前言 二、树上的DFS 1、树的重心 2、树的重心例题 3、树的直径 4、树的直径例题 &#xff08;1&#xff09;做两次DFS 三、拓扑排序与DFS 1、用DFS解拓扑排序 2、欧拉路与DFS 3、用DFS输出一个欧拉回路 一、前言 本文主要讲了树上的DFS、树的重心、树的直…

538. 把二叉搜索树转换为累加树

538. 把二叉搜索树转换为累加树 难度中等 给出二叉 搜索 树的根节点&#xff0c;该树的节点值各不相同&#xff0c;请你将其转换为累加树&#xff08;Greater Sum Tree&#xff09;&#xff0c;使每个节点 node 的新值等于原树中大于或等于 node.val 的值之和。 提醒一下&am…

关于浮点数使用的两个注意事项(C/C++)

目录 一.回顾浮点数的存储与读取 二.浮点数使用的第一个注意事项 三.浮点数使用的第二个注意事项 附&#xff1a; 观察内存中的FLT_MAX和FLT_MIN 一.回顾浮点数的存储与读取 http://t.csdn.cn/oVwte 浮点数的存入与读取流程总览&#xff1a; 二.浮点数使用的第一个注意事…

理解实现八大排序

目录 一、初步认识 二、直接插入排序 三、希尔排序 四、直接选择排序 五、堆排序 六、冒泡排序 七、快速排序 7.1 Hoare版本 7.2 挖坑法 7.3 前后指针法 7.4 非递归 7.5 优化方法 7.5.1 三数取中 7.5.2 小区间优化 八、归并排序 九、计数排序 一、初步认识 排…

Netty入门

二. Netty 入门 1. 概述 1.1 Netty 是什么&#xff1f; Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients.Netty 是一个异步的、基于事件驱动的网络应用框架&…

简单开发网站+HTML标签

目录 一、学习路线 二、快速开发网站 1、简单demo 2、浏览器能识别的标签 ① 编码② Title ③ 标题 ④ div和span ⑤ 超链接 ⑥ 图片⑦ 列表 ⑧ 表格 ⑨ input系列 ⑩ 下拉框 ⑪ 多行文本 三、网络请求 四、案例 1、用户注册 2、用户登录 五、小结 1、学习标签的总…

网易互客CRM 微盟系统 管易系统 金蝶系统对接集成整体解决方案

前言&#xff1a;大部分的企业都可能只用一套系统组织架构复杂&#xff0c;业务流程繁琐&#xff0c;内部同时有CRM系统、OMS系统、ERP系统......且各个系统都需要独立登陆&#xff0c;造成IT部门数据监管困难&#xff01;如何在同一套中台系统上关联多管理系统呢&#xff1f;系…

【GD32F427开发板试用】-03-定时器1 的不算坑的坑和时钟设置

本篇文章来自极术社区与兆易创新组织的GD32F427开发板评测活动&#xff0c;更多开发板试用活动请关注极术社区网站。作者&#xff1a;申小林 先说一下我使用定时器1 的时候吧&#xff0c;最开始我以为定时器1是挂在APB1上的&#xff0c;随意按照惯性思维&#xff0c;定时器的时…

vue3使用svg图标多种方式

方式1使用在线链接访问 在iconfont找到自己的项目的图标选择Symbol获取在线链接 2&#xff1a;在vue3项目中找到public的index.html进行script进行引入 打开浏览器看&#xff1a;这样就会自动注入到body下 在项目直接使用 //控制图标的大小<svg style"width: 10px; …