Codeforces 1133 F2. Spanning Tree with One Fixed Degree 并查集+生成树
好久没更新博客了,一直懒得动,这次更新一下。
题意大概是:给出一个图,求它的一个一号节点的度数恰好为D的生成树的方案。
一开始随便水了个乱搞贪心,不出意外并没有过。
仔细思考之后,对于这个问题我们可以先不管有一端是1的边,然后在这样的子图中,观察节点联通块的情况。

如上图,我们可以认为{2,5,6},{3,7},{4}分别是一个联通块。
为了保证最后生成树的连通性,显然每个联通块最少要连接一条对节点1的边。
这样一来我们就可以自由地连接剩下的边,当然,要符合生成树的性质,用并查集来判断是否能连接这条边。
于是我们用剩下的对1连接的边来使得1的度数符合要求。
然后接下来再用剩下的其他边补全生成树即可。
#include<bits/stdc++.h>
using namespace std;
int i,i0,n,m,D,pre[200005],pre0[200005];
bool vis[200005];
vector<int>v[200005];
vector<pair<int,int>>v0,ans;
int fin(int x){return (pre[x]==x)?x:pre[x]=fin(pre[x]);}
void uni(int x,int y){if(fin(x)!=fin(y))pre[fin(y)]=fin(x);}
int fin0(int x){return (pre0[x]==x)?x:pre0[x]=fin0(pre0[x]);}
void uni0(int x,int y){if(fin0(x)!=fin0(y))pre0[fin0(y)]=fin0(x);}
int main()
{
scanf("%d %d %d",&n,&m,&D);
for(i=1;i<=n;i++)pre[i]=pre0[i]=i;
for(i=1;i<=m;i++)
{
int x,y;
scanf("%d %d",&x,&y);
if(x>y)swap(x,y);
if(x!=1)uni(x,y),v0.push_back({x,y});
else vis[y]=1;
}
for(i=1;i<=n;i++)if(vis[i])v[fin(i)].push_back(i);
for(i=2;i<=n;i++)
{
if(fin(i)==i)
{
D--;
uni0(1,v[i][v[i].size()-1]);
ans.push_back({1,v[i][v[i].size()-1]});
v[i].pop_back();
}
}
for(i=2;i<=n;i++)
{
if(fin(i)==i)
{
while(D&&v[i].size())
{
D--;
uni0(1,v[i][v[i].size()-1]);
ans.push_back({1,v[i][v[i].size()-1]});
v[i].pop_back();
}
}
}
for(auto i:v0)if(fin0(i.first)!=fin0(i.second))uni0(i.first,i.second),ans.push_back({i.first,i.second});;
bool f=1;
for(i=2;i<=n;i++)if(fin0(i)!=fin0(1))f=0;
if(f&&!D)
{
printf("YES\n");
for(auto i:ans)printf("%d %d\n",i.first,i.second);
}
else printf("NO\n");
return 0;
}
Codeforces 1133 F2. Spanning Tree with One Fixed Degree 并查集+生成树的更多相关文章
- F2 - Spanning Tree with One Fixed Degree - 并查集+DFS
这道题还是非常有意思的,题意很简单,就是给定一个图,和图上的双向边,要求1号节点的度(连接边的条数)等于K,求这棵树的生成树. 我们首先要解决,如何让1号节点的度时为k的呢???而且求的是生成树,意思 ...
- [Educational Round 3][Codeforces 609E. Minimum spanning tree for each edge]
这题本来是想放在educational round 3的题解里的,但觉得很有意思就单独拿出来写了 题目链接:609E - Minimum spanning tree for each edge 题目大 ...
- codeforces 609E Minimum spanning tree for each edge
E. Minimum spanning tree for each edge time limit per test 2 seconds memory limit per test 256 megab ...
- Codeforces 938G 线段树分治 线性基 可撤销并查集
Codeforces 938G Shortest Path Queries 一张连通图,三种操作 1.给x和y之间加上边权为d的边,保证不会产生重边 2.删除x和y之间的边,保证此边之前存在 3.询问 ...
- Educational Codeforces Round 7 C. Not Equal on a Segment 并查集
C. Not Equal on a Segment 题目连接: http://www.codeforces.com/contest/622/problem/C Description You are ...
- Codeforces Round #181 (Div. 2) B. Coach 带权并查集
B. Coach 题目连接: http://www.codeforces.com/contest/300/problem/A Description A programming coach has n ...
- Educational Codeforces Round 1 D. Igor In the Museum bfs 并查集
D. Igor In the Museum Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/598 ...
- Codeforces #541 (Div2) - D. Gourmet choice(拓扑排序+并查集)
Problem Codeforces #541 (Div2) - D. Gourmet choice Time Limit: 2000 mSec Problem Description Input ...
- codeforces 811E Vladik and Entertaining Flags(线段树+并查集)
codeforces 811E Vladik and Entertaining Flags 题面 \(n*m(1<=n<=10, 1<=m<=1e5)\)的棋盘,每个格子有一个 ...
随机推荐
- 超详细的HashMap解析(jdk1.8)
目录 一.预备知识 时间复杂度 基本数据结构 基本位运算 二.HashMap实现原理 结构 速度 三.源码分析 基本常量 基本成员变量 构造方法 put方法 remove 四.日常使用注意事项 五.总 ...
- 15、springboot访问html文件
在pom.xml加入 <parent> <groupId>org.springframework.boot</groupId> <artifactId> ...
- 【 js 模块加载 】【源码学习】深入学习模块化加载(node.js 模块源码)
文章提纲: 第一部分:介绍模块规范及之间区别 第二部分:以 node.js 实现模块化规范 源码,深入学习. 一.模块规范 说到模块化加载,就不得先说一说模块规范.模块规范是用来约束每个模块,让其必须 ...
- 【 js 片段 】点击空白或者页面其他地方,关闭弹框
$(document).mouseup(function(e){ var _con = $(' 目标区域 '); // 设置目标区域 if(!_con.is(e.target) && ...
- Win8操作系统下IIS如何配置asp.net的运行环境(win7同样)
一.把鼠标放在电脑屏幕的左下角然后右击,弹出如下图菜单,选择“程序和功能”(快捷键win+X).(win7点击电脑左下角的“开始”,然后点击“控制面板”打开程序与功能界面): 二.进入程序与功能界面后 ...
- iview select下拉bug
1场景:弹框内有一个下拉组件(支持搜索),当选择完数据后弹框关闭,再次打开后,下拉框内的数据是刚才选中的数据.原因:分析后觉得是搜索内容没有清空,导致下拉的数据只有一个解决:调用下setQuery方法 ...
- <Android 基础(二十五)> Frame Animation
简介 Frame Animation, 逐帧动画,通过定义一系列的Drawable对象来实现动画效果,可以用来作为视图的背景. Frame Animation在代码中体现为AnimationDrawa ...
- 对象的数据属性(Object)
value: 对象属性的默认值,默认值为undefined configurable: 能否使用delete.能否需改属性特性.或能否修改访问器属性.,false为不可重新定义,默认值为true en ...
- PHP获取用户的真实IP地址
本文出至:新太潮流网络博客 PHP获取用户的真实IP地址,非代理IP function getClientIP(){ global $ip; if(getenv("HTTP_CLIENT_I ...
- mongodb/python3.6/mysql的安装
1 下载与解压 在官网下载mongodb安装包 tar -zxvf mongodb-linux-x86_64-ubuntu1604-3.4.0.tgz 2 移动安装文件 sudo mv mongodb ...