set集合使用详解

set集合使用详解set集合使用详解“曾经年少爱追梦,一心只想往前飞。”那会高二,刚刚接触c语言,一发不可收拾,还记得当时为了一个想法和朋友一起想到半夜。现在我还是那个少年,那个又菜又爱玩的少年。咳咳,set集合容器,非常好哈!内部是用二叉搜索树实现的,重点是什么呢,容器内每一个元素呀,它只会出现一次,并且是排好序的,你爱了吗?复杂度更是只有O(log2n),非常高效呢。set算是竞赛里面用的比较多的了,因为,很多题目都爱考一些集合什么的。咳咳,来看看使用方式吧。上表:写法说明set

大家好,又见面了,我是你们的朋友全栈君。

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晚——————————


改革尚未成功,同志仍需努力!!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/132402.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 如何将ip划分到vlan_两个vlan有同一mac

    如何将ip划分到vlan_两个vlan有同一macVLANVLAN技术主要就是在二层数据包的包头加上tag标签,表示当前数据包归属的vlan号。VLAN的主要优点:(1)广播域被限制在一个VLAN内,节省了带宽,提高了网络处理能力。(2)增强局域网的安全性:VLAN间不能直接通信,即一个VLAN内的用户不能和其它VLAN内的用户直接通信,而需要通过路由器或三层交换机等三层设备。(3)灵活构建虚拟工作组:用VLAN可以划分不同的用户…

    2022年8月10日
    4
  • 关于web前端性能优化总结[通俗易懂]

    关于web前端性能优化总结[通俗易懂]1、从DOM结构和标签上来优化·使用语义化的标签,代码清晰简洁;·减少Dom节点,增加渲染速度;·使用W3C标准书写闭合小写的标签;·给图片和table指定宽高,避免缩放;·防止src和href值为空,当为空时,浏览器会把当前页面当做属性值重新加载;·css在头部位置,js在body底部位置; 2、从CSS样式上来优化·使用link加载样式而不是@import(是css2提供的一种方式,不兼容,只…

    2022年6月16日
    30
  • idea查看激活码_通用破解码

    idea查看激活码_通用破解码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月15日
    59
  • docker部署web项目_docker web管理工具

    docker部署web项目_docker web管理工具前言前面我们运行的容器并没有一些什么特别的用处。接下来让我们尝试使用docker构建一个web应用程序。我们将在docker容器中运行一个PythonFlask应用来运行一个web

    2022年7月31日
    3
  • Spring概述「建议收藏」

    Spring概述「建议收藏」Spring概述

    2022年4月22日
    48
  • 彻底搞懂0-1背包问题(动态规划)

    彻底搞懂0-1背包问题(动态规划)看了很多网上的博客,发现对于0-1背包问题很多讲的都很专业,初学者学起来还是比较吃力,今天我就用最简单最形象的语言来描述一下0-1背包问题,为什么不能用贪婪算法,而要选择使用动态规划。首先对于0-1背包问题,我们需要知道的是:每一个物品只有1个,要么全拿,要么不拿,最后使得拿到的物品的总价值最大。假如一个小偷有一个可以容纳4千克的背包,但是发现面前只有有3样物品可以偷:台灯(30元,4千克)、音响(20元,3千克)、充电宝(15元,1千克)(价格和重量可能有点奇怪????)。问,小偷能够偷到的物品的

    2022年7月26日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号