[UVALive 3902] Network
图片加载可能有点慢,请跳过题面先看题解,谢谢





一道简单的贪心题,而且根节点已经给你了(\(S\)),这就很好做了。
显然,深度小于等于 \(k\) 的都不用管了(\(S\) 深度为0),那么我们只需要处理深度大于 \(k\) 的叶子节点。
这里有一个显而易见的贪心策略:
每次找一个深度最深的没有被覆盖的叶子节点,然后在它的 \(k\) 级祖先上放置服务器,覆盖服务器的周围 \(k\) 层节点。
反复这个操作直到所有节点都被覆盖。
//made by Hero_of_Someone
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#define il inline
#define RG register
using namespace std;
il int gi(){ RG int x=0,q=1; RG char ch=getchar(); while( ( ch<'0' || ch>'9' ) && ch!='-' ) ch=getchar();
  if( ch=='-' ) q=-1,ch=getchar(); while(ch>='0' && ch<='9') x=x*10+ch-48,ch=getchar(); return q*x; }
bool vis[1010];
int T,n,k,s,ans;
int size[1010],fa[1010],que[1010][1010];
int num,head[1010],nxt[2010],to[2010];
il void add(int u,int v){
   nxt[++num]=head[u];to[num]=v;head[u]=num;
   nxt[++num]=head[v];to[num]=u;head[v]=num;
}
il void dfs(int x,int f,int d){
   size[x]=1;fa[x]=f;
   for(RG int i=head[x];i;i=nxt[i]){
      RG int v=to[i]; if(v==f) continue;
      dfs(v,x,d+1); size[x]+=size[v];
   }
   if(size[x]==1 && d>k) que[d][++que[d][0]]=x;
}
il void init(){
   n=gi(),s=gi(),k=gi(),num=0;
   memset(que,0,sizeof(que));
   memset(vis,0,sizeof(vis));
   memset(head,0,sizeof(head));
   memset(size,0,sizeof(size));
   for(RG int i=1;i<n;i++){
      RG int u=gi(),v=gi();
      add(u,v);
   } dfs(s,0,0);
}
il void Dfs(int x,int f,int d){
   vis[x]=1; if(d>=k) return ;
   for(RG int i=head[x];i;i=nxt[i]){
      RG int v=to[i];
      if(v==f) continue;
      Dfs(v,x,d+1);
   }
}
il void work(){ ans=0;
   for(RG int d=n-1;d>k;d--){
      for(RG int i=1;i<=que[d][0];i++){
         RG int x=que[d][i];
         if(vis[x]) continue;
         RG int cur=x;
         for(RG int j=1;j<=k;j++) cur=fa[cur];
         Dfs(cur,0,0);
         ans++;
      }
   }
   printf("%d\n",ans);
}
int main(){ T=gi(); while(T--){ init(); work(); } return 0; }
												
											[UVALive 3902] Network的更多相关文章
- UVALive 3902 Network (树+dfs)
		
Consider a tree network with n nodes where the internal nodes correspond to servers and the terminal ...
 - UVaLive 3902 Network (无根树转有根树,贪心)
		
题意:一个树形网络,叶子是客户端,其他的是服务器.现在只有一台服务器提供服务,使得不超k的客户端流畅,但是其他的就不行了, 现在要在其他结点上安装服务器,使得所有的客户端都能流畅,问最少要几台. 析: ...
 - LA 3902 Network(树上最优化 贪心)
		
Network Consider a tree network with n <tex2html_verbatim_mark>nodes where the internal nodes ...
 - UVALive 3902 网络
		
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
 - LA 3902 Network
		
人生第一道图论题啊,有木有 题意: 有一个树状网络,有一个原始服务器s,它的服务范围是k 问至少再放多少台服务范围是k的服务器才能使网络中的每个节点都被覆盖掉 解法: 我们以原始服务器为根将其转化成一 ...
 - Uva LA 3902 - Network 树形DP 难度: 0
		
题目 https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_pr ...
 - Uva 3902 Network
		
题目大意: 在非叶子节点上安装最少的服务器使得,每个叶子节点到服务器的距离不超过k. 贪心+图上的dfs. 先从深度最大的叶子节点开始找.找到父节点后再用这个父节点进行扩充. /* ********* ...
 - UVALive3902 Network[贪心 DFS&&BFS]
		
UVALive - 3902 Network Consider a tree network with n nodes where the internal nodes correspond to s ...
 - 辣些数据结构的思维题(思维题好难一个都不会TAT)
		
洛谷P1268 树的重量 我觉得难点在于把每个叶子节点想象成分出来的叉 然后如果c是a--b这条边上分出来的,可以通过Dab,Dca,Dcb算出分叉边的长度, 长度=(Dac+Dbc-Dab)/2 怎 ...
 
随机推荐
- oracle表空间的创建及dmp 文件的导入
			
--用oracle系统权限的账号 登陆 -- 1.创建用户 create user u_name identified by "u_password"; --2.赋予权限 gran ...
 - Unity_屏幕/Viewport/世界坐标的转换
			
Unity_屏幕/Viewport/世界/UI坐标的转换 参考: https://www.jianshu.com/p/b5b6ac9ab145 -- 世界.视口.屏幕坐标转换 https://docs ...
 - vue处理循环列表动态数据问题
			
调用方法:Vue.set( target, key, value ) target:要更改的数据源(可以是对象或者数组) key:要更改的具体数据 value :重新赋的值 <!DOCTYPE ...
 - RabbitMQ入门:发布/订阅(Publish/Subscribe)
			
在前面的两篇博客中 RabbitMQ入门:Hello RabbitMQ 代码实例 RabbitMQ入门:工作队列(Work Queue) 遇到的实例都是一个消息只发送给一个消费者(工作者),他们的消息 ...
 - CentOS删除安装的程序
			
以mysql举例: 首先查询安装包: rpm -qa|grep mysql 查询到的一个结果为:mysql-community-libs-5.7.13-1.el6.x86_64 yum 删除 yum ...
 - 什么是mvc模式
			
MVC是一个架构,或者说是一个设计模式,它就是强制性使应用程序的输入,处理和输出分开.将一个应用程序分为三个部分:Model,View,Controller. 原理图: 分析: Model 模型(完成 ...
 - DDMS_Threads的简单使用
			
title: DDMS_Threads的简单使用 date: 2016-07-20 00:44:35 tags: [DDMS] categories: [Tool,IDE] --- 概述 本文记录在 ...
 - git 查看对比分支commit命令笔记
			
git log newheader(branch1) ^release(branch2) -- branch1 上比branch2多的commit 注意brnach2后面要--
 - Daily Scrum1 11.3
			
今天是我们团队进入代码实现阶段的第一天,经过一周对上一届项目代码的阅读和研究,队员们已经从代码中分析出我们这次项目将要修改和补充的地方,我们接下来要做的地方就是在两周的时间内将团队项目在alpha阶段 ...
 - web14 validation.xml配置 登录验证文件配置
			
电影网站:www.aikan66.com 项目网站:www.aikan66.com 游戏网站:www.aikan66.com 图片网站:www.aikan66.com 书籍网站:www.aikan66 ...