2007LA 3902 网络(树+贪心)
https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=283&page=show_problem&problem=1903
题意:在一个树状的网络中,提供VOD服务,叶子节点是客户端,其他是服务器,要减少网络延迟,所以要在其他的服务器也安装同样的服务,使得每台客户端到最近服务器的距离不超过k,求最少安装服务的服务器。
思路:一个关键点是选择u节点的k级祖先是最优的,因为覆盖的范围最广,所以我们构造出一颗有根树,从下往上遍历叶子节点,看是否被覆盖,没有则在k级祖先安装服务。
#include <iostream>
#include <vector>
using namespace std; #define MAXN 1010
vector<int> link[MAXN];//存树
vector<int> node[MAXN];//存第i层节点 int n, s, k, father[MAXN];
bool used[MAXN]; void dfs(int u, int fa, int d)//无根树转有根树,计算father数组,根据深度插入node表
{
father[u] = fa;
int size = link[u].size();
if (size == 1 && d > k) node[d].push_back(u);//一个
for (int i = 0; i < size; i++) //多个
{
if (link[u][i] != fa) dfs(link[u][i], u, d + 1);
}
} void dfs2(int u, int fa, int d)
{
used[u] = true;
for (int i = 0; i < link[u].size(); i++)
{
if (link[u][i] != fa && d < k) dfs2(link[u][i], u, d + 1);
}
} int solve()
{
int ans = 0;
memset(used, 0, sizeof(used));
for (int d = n - 1; d > k; d--)
{
for (int i = 0; i < node[d].size(); i++)
{
int u = node[d][i];
if (!used[u]) //未被覆盖
{
int tmp = u;
for (int j = 0; j < k; j++) tmp = father[tmp];//tmp是u的k级祖先
dfs2(tmp, -1 ,0);
ans ++;
}
}
}
return ans;
} int main()
{
int T;
cin>>T;
while (T--)
{
cin>>n>>s>>k;
for (int i = 1; i <= n; i++)
{
link[i].clear();
node[i].clear();
}
for (i = 0; i < n - 1; i++)
{
int a, b;
cin>>a>>b;
link[a].push_back(b);
link[b].push_back(a);
}
dfs(s, -1, 0);//节点,父节点,深度
printf("%d\n", solve());
}
return 0;
}
2007LA 3902 网络(树+贪心)的更多相关文章
- poj3764(dfs+Trie树+贪心)
		题目链接:http://poj.org/problem?id=3764 分析:好题!武森09年的论文中有道题CowXor,求的是线性结构上的,连续序列的异或最大值,用的办法是先预处理出前n项的异或值, ... 
- BZOJ_1826_[JSOI2010]缓存交换 _线段树+贪心
		BZOJ_1826_[JSOI2010]缓存交换 _线段树+贪心 Description 在计算机中,CPU只能和高速缓存Cache直接交换数据.当所需的内存单元不在Cache中时,则需要从主存里把数 ... 
- Bzoj5251 线段树+贪心
		Bzoj5251 线段树+贪心 记录本蒟蒻省选后的第一篇题解!国际惯例的题面:首先这个东西显然是一棵树.如果我们把数值排序,并建立这棵树的dfs序,显然dfs序上的一个区间对应数值的一个区间,且根为数 ... 
- 【NOI2015】荷马史诗[Huffman树+贪心]
		#130. [NOI2015]荷马史诗 统计 描述 提交 自定义测试 追逐影子的人,自己就是影子. ——荷马 Allison 最近迷上了文学.她喜欢在一个慵懒的午后,细细地品上一杯卡布奇诺,静静地阅读 ... 
- 2018.10.20 NOIP模拟 蛋糕(线段树+贪心/lis)
		传送门 听说是最长反链衍生出的对偶定理就能秒了. 本蒟蒻直接用线段树模拟维护的. 对于第一维排序. 维护第二维的偏序关系可以借助线段树/树状数组维护逆序对的思想建立权值线段树贪心求解. 代码 
- 【BZOJ3261】最大异或和 Trie树+贪心
		[BZOJ3261]最大异或和 Description 给定一个非负整数序列 {a},初始长度为 N. 有 M个操作,有以下两种操作类型:1 .A x:添加操作,表示在序列末尾添加一个 ... 
- HDU 4825 Xor Sum(经典01字典树+贪心)
		Xor Sum Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 132768/132768 K (Java/Others) Total ... 
- NEUOJ711  异星工厂 字典树+贪心
		题意:你可以收集两个不相交区间的权值,区间权值是区间异或,问这两个权值和最大是多少 分析:很多有关异或求最大的题都是利用01字典树进行贪心,做这个题的时候我都忘了...最后是看别人代码的时候才想起来这 ... 
- codeforces 675E Trains and Statistic 线段树+贪心统计
		分析:这个题刚看起来无从下手 但是我们可以先简化问题,首先可以固定起点i,求出i+1到n的最小距离 它可以到达的范围是[i+1,a[i]],贪心的想,我们希望换一次车可以到达的距离尽量远 即:找一个k ... 
随机推荐
- django 时间计数
			value必须replace(tzinfo=None)变成datetime格式,否则格式不对不能相减. 
- ASP.NET MVC进阶之路:深入理解Controller激活机制并使用Ioc容器创建对象
			本文标题说是"深入理解Controller"其实有点“标题党”的味道了.本篇只会探讨"Controller"的激活机制,也就是如何创建Controller的并调 ... 
- Hadoop 2.x(YARN)安装配置LZO
			今天尝试在Hadoop 2.x(YARN)上安装和配置LZO,遇到了很多坑,网上的资料都是基于Hadoop 1.x的,基本没有对于Hadoop 2.x上应用LZO,我在这边记录整个安装配置过程 1. ... 
- Codeforces 435B. Pasha Maximizes
			简单贪心.... B. Pasha Maximizes time limit per test 1 second memory limit per test 256 megabytes input s ... 
- 开源 免费 java CMS - FreeCMS1.9 职位管理
			项目地址:http://code.google.com/p/freecms/ 职位管理 管理职位,实现招聘功能. 1. 职位管理 从左側管理菜单点击职位管理进入. 2. 加入职位 在职位列表下方点击& ... 
- sharePoint常用命令
			New-SPStateServiceDatabase -Name "StateServiceDatabase" | New-SPStateServiceApplication -N ... 
- linux cmd: linux下解压命令大全
			linux下解压命令大全 .tar 解包:tar xvf FileName.tar打包:tar cvf FileName.tar DirName(注:tar是打包,不是压缩!)———————————— ... 
- CCIE路由实验(8) -- QoS
			1.查看端口缺省的队列机制2.配置CB-WFQ3.配置CB-LLQ4.配置CB-Shapping在以太接口下5.配置CB-Shapping在FR接口下6.配置帧中继流量整形FRTS7.配置CB-Pol ... 
- Java I/O流-ObjectInputStream、ObjectOutputStream
			一.整体代码 ObjectStreamDemo.java import java.io.File; import java.io.FileInputStream; import java.io.Fil ... 
- 浙江大学PAT上机题解析之3-05. 求链式线性表的倒数第K项
			给定一系列正整数,请设计一个尽可能高效的算法,查找倒数第K个位置上的数字. 输入格式说明: 输入首先给出一个正整数K,随后是若干正整数,最后以一个负整数表示结尾(该负数不算在序列内,不要处理). 输出 ... 
