CodeForces 1198C 1199E Matching vs Independent Set
Time limit 1000 ms
Memory limit 262144 kB
这题是一场cf里,div1的第三题,div2的第5题
中文题意
给一张无向图,没说连通性,要你选出一个大小为n的匹配,或者大小为n的独立集。换句话说,要你选出n条互相没有公共点的边,要是没有就选出n个互相没有直接相邻的点。直接相邻:被一条给定边连接。
解题思路
官方题解
Let's try to take edges to matching greedily in some order. If we can add an edge to the matching (both endpoints are not covered), then we take it. It is easy to see that all vertices not covered by the matching form an independent set — otherwise we would add an edge to the matching. Either matching or independent set has size at least \(n\). Complexity — \(O(n+m)\).
我的想法
一开始看见觉得很玄学啊,但仔细一想还真是那么回事。是这么选:给了\(3n\)个点嘛,对于输入的每条边,如果两个端点都没被选择过,就把这条边附带这两个点选上,并把两个端点标记为用过。如果输入完,选择了足够数量的边(大于等于n),那就输出这些边就好。
如果边没选够,那么说明存在多于\(n\)个未使用的点(选一条边用掉2个点,而总共\(3n\)个点),这些点当中的每一个,它的邻居中已经没有未被使用的了。
因为如果一个点未被使用,且它的邻居也未被使用,那么之前选边的时候这条边就被选了,它也就被使用了,它和它的邻居就会被标记上被使用过。换句话说,这个未使用的点和其他未使用的点之间没有边相连,被孤立了。其他未使用的点也同理。
这剩下的至少\(n\)个点就是题目要的独立集啊。于是就输出这些点。
另外,如果选中的边数量正好等于\(n\),说明对应独立集的大小也是\(n\),这时候按题意随便输出一种就好。
cf上给这题打的构造、贪心、图论、排序的标签(排序?)。确实不需要排序吧……还是因为官方题解的第一句话——
Let's try to take edges to matching greedily in some order
然后有order这个词,就给它打上排序的标签?(突然杠精)
源代码
#include<stdio.h>
#include<string.h>
int T;
int n,m;
bool used[300010];//用于标记点是否被使用
int e[500010],cnt;//用于记录选中的边的编号和数量,用于输出
int main()
{
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
memset(used,0,(n+2)*3);
cnt=1;
for(int i=1,u,v;i<=m;i++)
{
scanf("%d%d",&u,&v);
if(!used[u]&&!used[v])
{
used[u]=used[v]=1;
e[cnt++]=i;
}
}
if(cnt>n)
{
puts("Matching");
for(int i=1;i<=n;i++)
{
printf("%d ",e[i]);
}
}
else
{
int num=0;
puts("IndSet");
for(int i=1;i<=3*n&&num<n;i++)//写的时候脑袋不清晰,WA了好几次,这个循环条件改了好几次
{
if(used[i]) continue;
printf("%d ",i);
num++;
}
}
puts("");
}
return 0;
}
CodeForces 1198C 1199E Matching vs Independent Set的更多相关文章
- Codeforces - 1198C - Matching vs Independent Set - 贪心
https://codeforces.com/contest/1198/problem/C 要选取一个大小大于等于n的匹配或者选取一个大小大于等于n的独立集. 考虑不断加入匹配集,最终加入了x条边. ...
- [codeforces 508E]Maximum Matching
题目:Maximum Matching 传送门:http://codeforces.com/contest/1038/problem/E 分析: 一个块拥有{color1,val,color2},两个 ...
- [Codeforces Round #508 (Div. 2)][Codeforces 1038E. Maximum Matching]
前几天给舍友讲这题的时候感觉挺有意思的,就贴上来吧... 题目链接:1038E - Maximum Matching 题目大意:有\(n\)个棒子,每个条两端有颜色\(c1,c2\)以及他的价值\(v ...
- CF Round #576 (Div. 2) Matching vs Independent Set
链接:Click here 题目意思:给你一个图,有3n个点,m条边,求是否有n条匹配边或n个独立点,其中匹配为没有公共点,独立为不相连 Solution: 考虑每个点对于第一种情况,最多只能贡献一次 ...
- Codeforces 1038E Maximum Matching
可能写了个假算法 假设定义:含有一个欧拉路的图为类欧拉图 欧拉路的定义:一个无向连通图中,存在一条路径对所有边都遍历且仅遍历一次:判断方法:该连通图中度为奇数的点的个数不能超过2,即为0或者2 题目解 ...
- 【CodeForces】CodeForcesRound576 Div1 解题报告
点此进入比赛 \(A\):MP3(点此看题面) 大致题意: 让你选择一个值域区间\([L,R]\),使得序列中满足\(L\le a_i\le R\)的数的种类数不超过\(2^{\lfloor\frac ...
- Codeforces Round #576 (Div. 1)
Preface 闲来无事打打CF,就近找了场Div1打打 这场感觉偏简单,比赛时艹穿的人都不少,也没有3000+的题 两三个小时就搞完了吧(F用随机水过去了) A. MP3 题意不好理解,没用翻译看了 ...
- Codeforces Round #576 (Div. 1) 简要题解 (CDEF)
1198 C Matching vs Independent Set 大意: 给定$3n$个点的无向图, 求构造$n$条边的匹配, 或$n$个点的独立集. 假设已经构造出$x$条边的匹配, 那么剩余$ ...
- Codeforces Round #576 (Div. 2) 题解
比赛链接:https://codeforc.es/contest/1199 A. City Day 题意:给出一个数列,和俩个整数\(x,y\),要求找到序号最靠前的数字\(d\),使得\(d\)满足 ...
随机推荐
- python+selenium控制浏览器窗口(刷新、前进、后退、退出浏览器)
调用说明: driver.属性值 变量说明: 1.driver.current_url:用于获得当前页面的URL 2.driver.title:用于获取当前页面的标题 3.driver.page_so ...
- javascript 异常处理
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- 剑指Offer编程题(Java实现)——从尾到头打印链表
题目描述 输入一个链表,按链表值从尾到头的顺序返回一个ArrayList. 解题思路 思路一:使用头插法 使用头插法可以得到一个逆序的链表.遍历链表,每次将所遍历节点插入到链表的头部. 头结点和第一个 ...
- HNUSTOJ-1636 心电图
1636: 心电图 时间限制: 1 Sec 内存限制: 128 MB提交: 583 解决: 231[提交][状态][讨论版] 题目描述 众所周知,ACM/ICPC实验室聚集了一堆学霸Orz 有学霸 ...
- Springboot+Jedis+Ehcache整合
项目结构概览: 1. 导包 <parent> <groupId>org.springframework.boot</groupId> <artifactId& ...
- k3 cloud在站点中新增用户
1.进去金蝶云企业平台: 网址:https://cloud.kingdee.com/pt/ 2.进入控制台页面,我的产品下面选择添加用户 去cloud平台新增并同步用户注册信息 3.去管理中心更新用户 ...
- python 调用dll 动态链接库 结构体参数及回调函数等示例
结构体示例: 这里是 C 代码的部分,主要是结构体的声明和回调函数定义. // 新版本定义 typedef enum { DevCard, DevLocator, DevReader } DevTyp ...
- 关于Windows 10上MarkdownPad2无法预览的解决办法
升级win10后,发现一直可以用的MarkdownPad2预览功能不可以用了.于是在网上搜索了一下,刚开始没有解决.不过现在可以了.现在把解决方案记录下来.Windows10上使用MarkdownPa ...
- jquery遍历标签中自定义的属性方法
在开发中我们有时会对html标签添加属性,如何遍历处理 <ul> <li name="li1" sortid="nav_1">aaaaa ...
- Linux下安装chrome浏览器
第一步:进入google-chrome官网下载chrome安装包 官网地址:https://www.google.cn/chrome/ 选择要下载的安装包 注意:这里有两个选项,请按照你安装的系统下载 ...