好久没更新博客了,一直懒得动,这次更新一下。

题意大概是:给出一个图,求它的一个一号节点的度数恰好为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 并查集+生成树的更多相关文章

  1. F2 - Spanning Tree with One Fixed Degree - 并查集+DFS

    这道题还是非常有意思的,题意很简单,就是给定一个图,和图上的双向边,要求1号节点的度(连接边的条数)等于K,求这棵树的生成树. 我们首先要解决,如何让1号节点的度时为k的呢???而且求的是生成树,意思 ...

  2. [Educational Round 3][Codeforces 609E. Minimum spanning tree for each edge]

    这题本来是想放在educational round 3的题解里的,但觉得很有意思就单独拿出来写了 题目链接:609E - Minimum spanning tree for each edge 题目大 ...

  3. 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 ...

  4. Codeforces 938G 线段树分治 线性基 可撤销并查集

    Codeforces 938G Shortest Path Queries 一张连通图,三种操作 1.给x和y之间加上边权为d的边,保证不会产生重边 2.删除x和y之间的边,保证此边之前存在 3.询问 ...

  5. 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 ...

  6. Codeforces Round #181 (Div. 2) B. Coach 带权并查集

    B. Coach 题目连接: http://www.codeforces.com/contest/300/problem/A Description A programming coach has n ...

  7. 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 ...

  8. Codeforces #541 (Div2) - D. Gourmet choice(拓扑排序+并查集)

    Problem   Codeforces #541 (Div2) - D. Gourmet choice Time Limit: 2000 mSec Problem Description Input ...

  9. codeforces 811E Vladik and Entertaining Flags(线段树+并查集)

    codeforces 811E Vladik and Entertaining Flags 题面 \(n*m(1<=n<=10, 1<=m<=1e5)\)的棋盘,每个格子有一个 ...

随机推荐

  1. 微软官方公布的Windows 8.1 Update常用快捷键

    以前用 Windows Server 2008R2,初装Win8.1,感觉最明显的是开关机速度真心快~下面摘录了常用的几个快捷键: Windows 键+D:显示或隐藏桌面 Windows键+X:访问Q ...

  2. Asp.net MVC流程简述

    先上个图 步骤一 IIS   当请求到达我们的服务器时,在asp.net取得控制之前,windows操作系统的核心组件 HTTP.SYS一直在监听请求端口,  接下来asp.net会通知所有注册的ht ...

  3. 设计模式学习——代理模式(Proxy Pattern)之 强制代理(强校验,防绕过)

    上周温习了代理模式:http://www.cnblogs.com/chinxi/p/7354779.html 在此进行拓展,学习强制代理.但是发现网上大多例子都有个“天坑”(我是这么认为的),在得到代 ...

  4. HTML5 FormData实现文件上传实例

    表单提交,文件上传是一个常用又十分麻烦的功能,以前要上传文件通常都是借助插件或者flash来实现,噼里啪啦的加载一大堆东西.自从有了HTML5的FormData后,老板再也不用担心我的上传了. For ...

  5. 移动端meta标签设置

    移动端meta标签设置 1.设置当前html文件的字符编码 <meta charset="UTF-8"> 1 2设置浏览器的兼容模式(让IE使用最新的浏览器渲染) &l ...

  6. PopupWindow 的常用api封装

    对PopupWindow常用API的简单封装,几行代码就搞定PopupWindow弹窗,使用Builder模式,链式调用,像使用AlertDialog 一样 封装通用PopupWindow,Custo ...

  7. 一些不错的Android开源音视频播放器

    摘要:来自Github上的一点点整理,希望对你有用! 整理了一下Github上几个开源的音视频播放器项目,有兴趣的同学可以clone代码去研究学习. 1.UniversalMusicPlayer ht ...

  8. Android Studio插件之MVPHelper,一键生成MVP代码

    MVP盛行,听到的最多的抱怨就是咋要写这么多接口,那么本文作者提供了一个插件,自动生成这些接口的声明.感兴趣的还可以学习该插件的写法,按照自己平时的需求修改,提供开发效率. MVPHelper 一款I ...

  9. frame shiro 认证示例及原理简述

    shiro 认证流程 1.创建一个 javaSE 的maven项目(quickstart),并添加依赖 <dependency> <groupId>junit</grou ...

  10. vue.js高仿饿了么(前期整理)

    1.熟悉项目开发流程 需求分析——>脚手架工具——>数据mock——>架构设计——>代码编写——>自测——>编译打包. 2.熟悉代码规范 从架构设计.组件抽象.模块 ...