set集合使用详解

article/2025/8/25 5:06:32

set集合使用详解

“曾经年少爱追梦,一心只想往前飞。”那会高二,刚刚接触c语言,一发不可收拾,还记得当时为了一个想法和朋友一起想到半夜。现在我还是那个少年,那个又菜又爱玩的少年。

  • 咳咳,set集合容器,非常好哈!内部是用二叉搜索树实现的,重点是什么呢,容器内每一个元素呀,它只会出现一次,并且是排好序的,你爱了吗?复杂度更是只有 O(log2n),非常高效呢。
  • set算是竞赛里面用的比较多的了,因为,很多题目都爱考一些集合什么的。
  • 咳咳,来看看使用方式吧。上表:
写法说明
set < type > s定义一个集合s
s.insert(item)把item放入s集合里面
s.erase(item)删除元素item
s.clear()清空s集合
s.empty()判断集合是否是空的
s.size()返回集合元素个数
s.find(k)返回一个迭代器,键值指向k
s.lower_bound(k)返回迭代器,键值指向不下于k的第一个元素
s.upper_bound(k)返回迭代器,键值指向大于k的第一个元素
  • 这就是集合的操作拉,是不是很简单呢。
  • 一起来看看实例吧!

在这里插入图片描述

  • 可以看到哈,1-6,9-4,我们移动插入了11个元素,但是最后输出的元素个数确实9个,那么,这是因为set集合会自动的去除那些重复的值。
  • 第二次输入值的时候,我们是反过来放入值的,但是输出的时候却是正的,这说明,他还可以排序哦。是不是超级好用!!!
  • 咳咳,竟然如此,我们直接上个题目来练练。

hdu 2094 “产生冠军”

题目链接:点我了解题目(这是一个链接)
有一群人,打乒乓球比赛,两两捉对撕杀,每两个人之间最多打一场比赛。
球赛的规则如下:
如果A打败了B,B又打败了C,而A与C之间没有进行过比赛,那么就认定,A一定能打败C。
如果A打败了B,B又打败了C,而且,C又打败了A,那么A、B、C三者都不可能成为冠军。
根据这个规则,无需循环较量,或许就能确定冠军。你的任务就是面对一群比赛选手,在经过了若干场撕杀之后,确定是否已经实际上产生了冠军。

输入样例:

3
Alice Bob
Smith John
Alice Smith
5
a c
c d
d e
b e
a d
0

输入样例:

Yes
No

  • 咳咳,很好理解哈,题目要求会不会产生冠军,那么首先哈,冠军只有一个,所以我们只要建立两个集合,一个用来装所有人,一个用来装失败的人,最后根据两个集合元素个数之差就可以判断出是否会出现冠军
  • 看清楚哈,这是多项数据哦。
#include<bits/stdc++.h>
using namespace std;
int main(){set<string > a;			//a集合用来装所有参加赛事的人 set<string > b;			//b集合用来装比赛失败的人 int n;while(~scanf("%d",&n)&&n){string s1,s2;a.clear();b.clear();for(int i=0;i<n;i++){cin >> s1 >> s2;a.insert(s1);a.insert(s2);b.insert(s2);}//cout << a.size() << " " << b.size() << endl;if(a.size()-b.size()==1)cout << "Yes" << endl;else cout << "No" << endl;}return 0;
}
  • 咳咳,这没啥好说的哈,就是这么简单,当然啦,简单不代表你可以不去打,不打永远的抖不会知道的。所以加油吧少年。
  • 再来一题,这次难一点点。冲冲冲!
  • 选自天梯赛真题哦

L2-005 集合相似度 (25分)

题目链接:点我了解题目(这是一个链接)

给定两个整数集合,它们的相似度定义为:N​c / N​t × 100%。其中 N​c 是两个集合都有的不相等整数的个数,N​是两个集合一共有的不相等整数的个数。你的任务就是计算任意一对给定集合的相似度。

输入样例:

3
3 99 87 101
4 87 101 5 87
7 99 101 18 5 135 18 99
2
1 2
1 3

输入样例:

50.00%
33.33%

  • 做题先看题,看题先读题,好,意意思就是把两个集合里面的都相等的个数比上两个集合加在一起的集合的个数,然后按照百分比输出就好啦!
  • 这里需要查找两个集合里面相等的个数,我们可以使用find方法直接去找,超级有效,如果单独创建集合去整合的话,最后大数据可能会超时哦!!!
#include<bits/stdc++.h>
using namespace std;
set<int > s[55];
int n,m;
void fun(int a,int b){int s1=0;int s2=0;set<int >::iterator it;for(it=s[a].begin();it!=s[a].end();it++){if(s[b].find(*it)!=s[b].end())s1++;}s2 = s[a].size() + s[b].size() - s1;double ans = s1 * 1.0 / s2 *100;printf("%.2lf%%\n",ans);
} 
int main(){int n,m,x;cin >> n;for(int i=1;i<=n;i++){cin >> m;for(int j=1;j<=m;j++){cin >> x;s[i].insert(x);}}int k;cin >> k;while(k--){int a,b;cin >> a >> b;fun(a,b);}return 0;
} 
  • 集合对于竞赛而言还是很重要的,大概率会出题。

  • 嗯嗯,学无止境,冲冲冲


  • 隶属于算法竞赛入门到进阶完整学习路线 <-----这是一个链接

------------------------------2020/12/18晚------------------------------
改革尚未成功,同志仍需努力!!!

http://chatgpt.dhexx.cn/article/jAdUP6Z2.shtml

相关文章

OBS录屏如何设置录制窗口大小?

1、在显示录制窗口区右键→滤镜→添加一个裁剪/填充→调整左右顶底部里的数字进行裁剪&#xff0c;调整到合适的录屏大小即可。

如何使用OBS 进行屏幕录制

软件界面 默认的保存位置 C:\Users\XXXX\Videos 如何对屏幕进行录制&#xff08;默认也录制了音频信号&#xff09;

obs屏幕录制暂停

OBS Studio 24.0 RC1 发布 – 有大惊喜OBS Studio 24.0 RC1 发布 – 有大惊喜 OBS Studio 24.0 RC1于今天下午发布&#xff0c;增加了在录制时暂停的功能&#xff0c;允许“无缝地实时删除视频片段”。OBS Studio 24.0 RC1还支持在发生拥塞时自动调整比特率&#xff0c;而不是丢…

OBS录屏软件使用指南

OBS录屏软件使用指南 1 简介2 录屏使用步骤2.1 来源2.2 设置2.2.1 输出2.2.2 视频 2.3 录制 3 总结 1 简介 2 录屏使用步骤 2.1 来源 在来源标签&#xff0c;添加显示器捕获。 2.2 设置 在录屏时&#xff0c;需要进行录屏设置&#xff0c;点击菜单栏文件->设置 2.2.1…

【录屏】OBS如何区域录制

OBS如何区域录制 按住alt拖动红色边框即可隐藏拖动的区域

OBS 录制简单操作说明

把从B站Sky灬素颜看到的关于OBS录制视频的部分文字记录下 视频地址 录制界面捕获 1.首先&#xff0c;新建一个场景。 2.在新建的场景下&#xff0c;点击右边的来源窗口&#xff0c;新建一个捕获方式。 &#xff08;此处注意被捕获的窗口不能最小化&#xff0c;需要浮在桌…

OBS录制黑屏的解决办法

前些时间打开下载了好久一直没打开的obs录屏软件&#xff0c;想把老师的直播网课录下来重复看&#xff0c;但是发现&#xff0c;无论是用显示器捕获还是窗口捕获都是黑屏&#xff0c;然后就百度找了挺多关键词的&#xff0c;有的方法奏效有的不行有的不全面&#xff0c;为了方便…

obs直播录屏软件下载使用教程-制作短视频录制视频教程

现在是短视频的时代&#xff0c;我们需要学一点视频处理技术&#xff0c;录屏也是一项基本能力 下载软件 这里我下载的是obs软件&#xff0c;可以录屏可以直播 https://obsproject.com/ 因为网络原因&#xff0c;一直没有下载成功&#xff0c;开启特殊上网&#xff0c;才算一点…

OBS录制设置基本介绍(1)

1.OBS OBS&#xff08;Open Broadcasting Software&#xff09;是一款免费且开源的跨平台直播和录制软件&#xff0c;它可以将电脑屏幕、摄像头、麦克风和音频源等多种内容混合在一起并进行直播或录制。 1)基本操作介绍&#xff1a; 下载 OBS官网 在OBS官网&#xff08;htt…

直播、录屏软件OBS Studio下载安装操作教程

直播、录屏软件OBS Studio下载安装操作教程 OBS Studio是一款非常强大的免费开源无广告&#xff0c;国外开发的软件&#xff0c;录屏只是它的一部分功能&#xff0c;对于需要录制屏幕又要录制摄像头的也很适合&#xff0c;比如现在的直播行业&#xff0c;这款软件是一个不二之…

录屏软件OBS录屏时噪声大的解决办法

1、选择麦克风的滤镜 2、点击右下角号&#xff0c;选择噪声抑制 3、点击确定即可&#xff0c;这样设置就完成了&#xff0c;最后关闭滤镜就可以无噪声录制视频了 你的点赞、评论、收藏和关注是我创作的动力。 感谢各位看官老爷

解决OBS录屏软件窗口采集不全的问题

问题描述 使用OBS录屏软件的窗口采集功能的时候&#xff0c;有时候窗口对象只能捕获到一部分&#xff0c;不能全屏都是目标对象。 解决办法

OBS视频录制及其直播推流教程(超详细,非硬核)

录制软件&#xff1a; OBS &#xff08;我用过很多录制软件&#xff0c;OBS是最好用的&#xff0c;没有之一&#xff0c;而且完全免费&#xff09; 功能&#xff1a;直播&#xff0c;录像&#xff08;录制游戏或者网课等等&#xff09; 我准备将我的教程分为多个部分&#xf…

OBS 安装与考试参数设置及屏幕无法完全捕获、录屏不完整的解决方法

目录 一、OBS 的下载与安装 二、OBS 考试参数设置 三、问题解决 &#xff08;1&#xff09;屏幕无法完全捕获 &#xff08;2&#xff09;录屏不完整 一、OBS 的下载与安装 官网&#xff08;Open Broadcaster Software | OBS&#xff09;选择对应的版本下载&#xff0c;自…

OBS 录制没有声音怎么办?

1.检查obs设置- 音频 -是否是默认选项 2.检查win10 是否允许使用麦克风 1&#xff09;右下角出现麦克风标识 2&#xff09;设置-隐私-麦克风&#xff0c;查看允许放开你的麦克风是否打开 如果上述还是为解决问题&#xff0c;那么接下来的就是关键 3. 控制面板 - 硬件和声音 …

20221130如何修改OBS录屏的存储路径?

obs https://obsproject.com/ OBS OBS Open Broadcaster Software OBS Studio Latest Release 28.1.2 - November 5th obs 录屏 更换保存位置 https://jingyan.baidu.com/article/67508eb4c854fbddca1ce481.html 20221130如何修改OBS录屏的存储路径&#xff1f; 如何修改OBS录…

CSP在线考试环境 | OBS录屏软件下载安装和设置教程

今年由于疫情原因&#xff0c;很多省份都申请在线参加CCF CSP-J/S考试。 本次在线考试采用双重保险方式&#xff0c;不仅要求有腾讯会议端的监考&#xff0c;还要求在考试电脑上要安装OBS录屏软件&#xff0c;进行全程录屏。最后&#xff0c;将两份录制的视频文档传回给CCF&am…

开源免费录屏和直播软件OBS Studio教程

转载于&#xff1a;https://zhuanlan.zhihu.com/p/107720665 OBS Studio是目前比较主流的免费开源录屏和直播软件&#xff0c;它提供了丰富的功能特性&#xff0c;可以媲美一些受欢迎的同类商业软件。如果你正在考虑使用低成本方案来录屏或进行直播&#xff0c;那么这将是一个…

OBS的录制流程

软件的录屏使用 界面介绍 录屏–首先添加显示器的源&#xff0c;&#xff08;可选&#xff09;配置下载路径以及参数配置&#xff0c;点击开始录制。默认下载在c盘用户名下的video文件夹下 调试obs项目&#xff0c;分析 obs-studio\UI\forms找到主界面ui文件&#xff0c;找…

视频录制工具OBS选择区域录制

视频录制工具OBS录制时默认是对整个屏幕区域进行录制的&#xff0c;如果我们想只是录取某一屏幕区域&#xff0c;就需要进行一些修改。 相关的修改步骤如下&#xff1a; &#xff08;1&#xff09;新建一个“显示器采集”。 在弹出的对话框中&#xff0c;指定名字。 接着&…