题意:

给你一幅图,你要用这些边构造一个树,

s和t两个节点的度数不能超过ds dt
而且图是保证没有环

思路:

树的性质是:无环(已经保证),无向(保证),连通(还要判断)

首先把S,T点从图里剥离出来,就是把S和T点搞成几个连通块

对于这些连通块有三种:只与S连的,只与T连的,还有一种是两个都连的,

然后就是要把S和T与那些连通块相连,保证连通。

由于对于S和T相连的点并不是连通块的老大,而且S和T连出去的点还可能同时在一个连通块里;

所以预处理一下S和T连接点的老大,塞到set里去去个重,连一个子节点或者就是他本身就好了;

中间还要判断S和T的连通性,最后再判断一下度数就好啦

PS:主要是要知道树的性质,还有就是要知道树的哪些边是一定要连的;

好菜啊!!!

#include <bits/stdc++.h>
using namespace std; const int N=2e5+10; vector<int>ma[N];
vector<int>ans[N],tt[N],ss[N];
set<int>s;
set<int>t;
int num[N];
int S,T;
int pre[N]; void dfs(int x,int k)
{
pre[x]=k;
for(int i=0;i<ma[x].size();i++)
{
//printf("%d\n",ma[x][i]);
if(ma[x][i]==S||ma[x][i]==T||pre[ma[x][i]])
continue;
ans[x].push_back(ma[x][i]);
dfs(ma[x][i],k);
}
} int main()
{
int n,m;
int x,y;
int ds,dt;
int ps,pt;
scanf("%d%d",&n,&m);
while(m--)
{
scanf("%d%d",&x,&y);
ma[x].push_back(y);
ma[y].push_back(x);
}
scanf("%d%d%d%d",&S,&T,&ds,&dt);
//首先剥离与s和t连通的东东;
memset(pre,0,sizeof(pre));
for(int i=1;i<=n;i++)
{
if(i==S||i==T||pre[i])
continue;
dfs(i,i);
}
//然后就是从s的一些连通块,或者从t出发的一些连通块
int flag=0;
ps=pt=0;
memset(num,0,sizeof(num));
//建下边,去个重;
for(int i=0;i<ma[S].size();i++)
{
if(ma[S][i]==T)
{
flag++;
continue;
}
s.insert(pre[ma[S][i]]);
ss[pre[ma[S][i]]].push_back(ma[S][i]);
}
for(int i=0;i<ma[T].size();i++)
{
if(ma[T][i]==S)
continue;
t.insert(pre[ma[T][i]]);
tt[pre[ma[T][i]]].push_back(ma[T][i]);
} set<int>::iterator it;
for(it=s.begin();it!=s.end();it++)
num[*it]++;
for(it=t.begin();it!=t.end();it++)
{
num[*it]++;
if(num[*it]==1)
{
ans[T].push_back(tt[*it][0]);
num[*it]=0;
pt++;
}
}
for(it=s.begin();it!=s.end();it++)
{
if(num[*it]==1)
{
ans[S].push_back(ss[*it][0]);
num[*it]=0;
ps++;
}
}
int ff=0;
for(it=s.begin();it!=s.end();it++)
{
if(num[*it]>1)
{
if(!ff)
{
ans[S].push_back(ss[*it][0]);
ans[T].push_back(tt[*it][0]);
ps++;
pt++;
ff=1;
continue;
}
if(ps<ds)
{
ans[S].push_back(ss[*it][0]);
ps++;
}
else//不行的话只能给T啊!!!;
{
ans[T].push_back(tt[*it][0]);
pt++;
}
}
}
if(!ff)//如果不能搞在一起的话
{
if(flag)//判断是否本来就在一起
{
ans[S].push_back(T);
ps++;
pt++;
}
else
{
puts("NO");
return 0;
}
}
if(ps>ds||pt>dt)
puts("No");
else
{
puts("Yes");
for(int i=1;i<=n;i++)
{
for(int j=0;j<ans[i].size();j++)
{
printf("%d %d\n",i,ans[i][j]);
}
}
}
return 0;
}

CodeForces 723F【DFS瞎搞】的更多相关文章

  1. Codeforces Gym 100610 Problem H. Horrible Truth 瞎搞

    Problem H. Horrible Truth Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/1006 ...

  2. 8VC Venture Cup 2016 - Elimination Round B. Cards 瞎搞

    B. Cards 题目连接: http://www.codeforces.com/contest/626/problem/B Description Catherine has a deck of n ...

  3. HDU5971【瞎搞】

    题意:略(忙着准备文化课...明天期中考啊.... 思路: 正解就是染色,2-sat搞: AC代码(虽然是错误的...数据水(过踏马的也行啊,起码打脸他啊!) 4 3 1 0 1 2 2 3 3 4 ...

  4. UVA 11853 [dfs乱搞]

    /* 大连热身E题 不要低头,不要放弃,不要气馁,不要慌张 题意: 在1000×1000的格子内有很多个炮弹中心,半径给定. 为某人能否从西部边界出发,从东部边界走出. 不能输出不能,能的话输出最北边 ...

  5. URAL 1203. Scientific Conference(瞎搞)

    题目链接 本来觉得这不是经典的贪心吗..果断水一次,wa了,看了看discuss,发现貌似不好水,土土的DP了一下,复杂度很高了,又T了...然后想想单调队列,二分什么的...不好往上加,直接搞了标记 ...

  6. B. Salty Fish Go! -期望题(瞎搞题)

    链接:https://www.nowcoder.com/acm/contest/104/B来源:牛客网 题意:A few days ago, WRD was playing a small game ...

  7. HDU5532 Almost Sorted Array(最长上升子序列 or 瞎搞个做差的数组)

    题目链接:点我 题意:给定一个序列,询问是否能删除一个数让它成为非递减或者非递增的序列. 比如说 删除后的序列是1 3 3 5 或者5 3 3 1 或者1 3 5 或者5 3 1 都可以.只要满足删掉 ...

  8. TOJ3097: 单词后缀 (字典树 or map瞎搞)

    传送门 (<---可以点击的~) 时间限制(普通/Java):1000MS/3000MS     内存限制:65536KByte 描述 有些英语单词后缀都是一样的,现在我们需要从给定的一堆单词里 ...

  9. ubuntu--基础环境瞎搞集合

    安装ubuntu系统后有很多东西需要自己瞎搞一下,这里把一些瞎搞的过程记录在这里,方便以后重新装系统后重新配置. 一.安装. 可以在windows下制作启动盘(软碟通),然后开机u盘启动即可安装,预留 ...

随机推荐

  1. 两个经典的文件IO程序示例

    前言 本文分析两个经典的C++文件IO程序,提炼出其中文件IO的基本套路,留待日后查阅. 程序功能 程序一打印用户指定的所有文本文件,程序二向用户指定的所有文本文件中写入数据. 程序一代码及其注释 # ...

  2. 【转】安卓逆向实践5——IDA动态调试so源码

    之前的安卓逆向都是在Java层上面的,但是当前大多数App,为了安全或者效率问题,会把一些重要功能放到native层,所以这里通过例子记录一下使用IDA对so文件进行调试的过程并对要点进行总结. 一. ...

  3. scikit-learn:4.2. Feature extraction(特征提取,不是特征选择)

    http://scikit-learn.org/stable/modules/feature_extraction.html 带病在网吧里. ..... 写.求支持. .. 1.首先澄清两个概念:特征 ...

  4. POJ 2263 Heavy Cargo(ZOJ 1952)

    最短路变形或最大生成树变形. 问 目标两地之间能通过的小重量. 用最短路把初始赋为INF.其它为0.然后找 dis[v]=min(dis[u], d); 生成树就是把最大生成树找出来.直到出发和终点能 ...

  5. 线程中调用Updatedata的问题

    随便发个自定义消息,然后在 CMyDialog的自定义消息处理函数中 UpdateDate().因为 UpdateDate用到了线程本地存储.不能跨线程的 UpdateData只能在主线程中使用,将U ...

  6. 在Android中使App高速、简单地支持新浪微博、微信、QQ、facebook等十几个主流社交平台的分享功能

    前言 在如今的APP或者游戏中,分享功能差点儿已经成为标配.分享功能不但能够满足用户的需求.也能够为产品带来很多其它的用户,甚至能够对用户的行为.活跃度.年龄段等情况进行数据统计,使得软件公司能够对产 ...

  7. the algebra of modulo-2 sums disk failure recovery

    x=y x_+_y=0 The bit in any position is the modulo-2 sum of all the bits in the corresponding positio ...

  8. struts2的核心和工作原理 (转)

    转自--------http://blog.csdn.net/laner0515/article/details/27692673 在学习struts2之前,首先我们要明白使用struts2的目的是什 ...

  9. java.lang.ClassNotFoundException: Didn't find class "org.reactivestreams.Publisher" on path

    缺少jar包  reactive-streams-1.0.0.jar  和  reactive-streams-1.0.0-sources.jar 常用于  Rxjava 开发过程中 <?xml ...

  10. 查看ubuntu磁盘空间占用及占用空间大的文件

    最近老是收到 ecs上有台服务器的磁盘利用率高 终于有一天 ssh登不上去了 http://blog.csdn.net/aaashen/article/details/50685988 清除相关大文件 ...