https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=283&page=show_problem&problem=1903

题意:在一个树状的网络中,提供VOD服务,叶子节点是客户端,其他是服务器,要减少网络延迟,所以要在其他的服务器也安装同样的服务,使得每台客户端到最近服务器的距离不超过k,求最少安装服务的服务器。

思路:一个关键点是选择u节点的k级祖先是最优的,因为覆盖的范围最广,所以我们构造出一颗有根树,从下往上遍历叶子节点,看是否被覆盖,没有则在k级祖先安装服务。

  1. #include <iostream>
  2. #include <vector>
  3. using namespace std;
  4.  
  5. #define MAXN 1010
  6. vector<int> link[MAXN];//存树
  7. vector<int> node[MAXN];//存第i层节点
  8.  
  9. int n, s, k, father[MAXN];
  10. bool used[MAXN];
  11.  
  12. void dfs(int u, int fa, int d)//无根树转有根树,计算father数组,根据深度插入node表
  13. {
  14. father[u] = fa;
  15. int size = link[u].size();
  16. if (size == 1 && d > k) node[d].push_back(u);//一个
  17. for (int i = 0; i < size; i++) //多个
  18. {
  19. if (link[u][i] != fa) dfs(link[u][i], u, d + 1);
  20. }
  21. }
  22.  
  23. void dfs2(int u, int fa, int d)
  24. {
  25. used[u] = true;
  26. for (int i = 0; i < link[u].size(); i++)
  27. {
  28. if (link[u][i] != fa && d < k) dfs2(link[u][i], u, d + 1);
  29. }
  30. }
  31.  
  32. int solve()
  33. {
  34. int ans = 0;
  35. memset(used, 0, sizeof(used));
  36. for (int d = n - 1; d > k; d--)
  37. {
  38. for (int i = 0; i < node[d].size(); i++)
  39. {
  40. int u = node[d][i];
  41. if (!used[u]) //未被覆盖
  42. {
  43. int tmp = u;
  44. for (int j = 0; j < k; j++) tmp = father[tmp];//tmp是u的k级祖先
  45. dfs2(tmp, -1 ,0);
  46. ans ++;
  47. }
  48. }
  49. }
  50. return ans;
  51. }
  52.  
  53. int main()
  54. {
  55. int T;
  56. cin>>T;
  57. while (T--)
  58. {
  59. cin>>n>>s>>k;
  60. for (int i = 1; i <= n; i++)
  61. {
  62. link[i].clear();
  63. node[i].clear();
  64. }
  65. for (i = 0; i < n - 1; i++)
  66. {
  67. int a, b;
  68. cin>>a>>b;
  69. link[a].push_back(b);
  70. link[b].push_back(a);
  71. }
  72. dfs(s, -1, 0);//节点,父节点,深度
  73. printf("%d\n", solve());
  74. }
  75. return 0;
  76. }

2007LA 3902 网络(树+贪心)的更多相关文章

  1. poj3764(dfs+Trie树+贪心)

    题目链接:http://poj.org/problem?id=3764 分析:好题!武森09年的论文中有道题CowXor,求的是线性结构上的,连续序列的异或最大值,用的办法是先预处理出前n项的异或值, ...

  2. BZOJ_1826_[JSOI2010]缓存交换 _线段树+贪心

    BZOJ_1826_[JSOI2010]缓存交换 _线段树+贪心 Description 在计算机中,CPU只能和高速缓存Cache直接交换数据.当所需的内存单元不在Cache中时,则需要从主存里把数 ...

  3. Bzoj5251 线段树+贪心

    Bzoj5251 线段树+贪心 记录本蒟蒻省选后的第一篇题解!国际惯例的题面:首先这个东西显然是一棵树.如果我们把数值排序,并建立这棵树的dfs序,显然dfs序上的一个区间对应数值的一个区间,且根为数 ...

  4. 【NOI2015】荷马史诗[Huffman树+贪心]

    #130. [NOI2015]荷马史诗 统计 描述 提交 自定义测试 追逐影子的人,自己就是影子. ——荷马 Allison 最近迷上了文学.她喜欢在一个慵懒的午后,细细地品上一杯卡布奇诺,静静地阅读 ...

  5. 2018.10.20 NOIP模拟 蛋糕(线段树+贪心/lis)

    传送门 听说是最长反链衍生出的对偶定理就能秒了. 本蒟蒻直接用线段树模拟维护的. 对于第一维排序. 维护第二维的偏序关系可以借助线段树/树状数组维护逆序对的思想建立权值线段树贪心求解. 代码

  6. 【BZOJ3261】最大异或和 Trie树+贪心

    [BZOJ3261]最大异或和 Description 给定一个非负整数序列 {a},初始长度为 N.       有   M个操作,有以下两种操作类型:1 .A x:添加操作,表示在序列末尾添加一个 ...

  7. HDU 4825 Xor Sum(经典01字典树+贪心)

    Xor Sum Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 132768/132768 K (Java/Others) Total ...

  8. NEUOJ711 异星工厂 字典树+贪心

    题意:你可以收集两个不相交区间的权值,区间权值是区间异或,问这两个权值和最大是多少 分析:很多有关异或求最大的题都是利用01字典树进行贪心,做这个题的时候我都忘了...最后是看别人代码的时候才想起来这 ...

  9. codeforces 675E Trains and Statistic 线段树+贪心统计

    分析:这个题刚看起来无从下手 但是我们可以先简化问题,首先可以固定起点i,求出i+1到n的最小距离 它可以到达的范围是[i+1,a[i]],贪心的想,我们希望换一次车可以到达的距离尽量远 即:找一个k ...

随机推荐

  1. Linux如何修改SSH端口号

    SSH是什么? SSH 为 Secure Shell 由 IETF 的网络工作小组(Network Working Group)所制定: SSH 是建立在应用层和传输层基础上的一种安全协议. SSH传 ...

  2. mysql中if语句

    #1.IF表达式 IF(condition,expr1,expr2) //如果condition成立返回expr1,否则返回expr2 #2.IFNULL表达式 IFNULL(expr1,expr2) ...

  3. PyQt中弹出对话框操作

    经常有初学者搞不清楚如何在PyQt中弹出对话框,以及如何处理返回值.这篇文章会举例说明,界面采用手工编写. 我们一般说的对话框指的是模态对话框(Modal Dialogue Box),一旦弹出,就不能 ...

  4. ognl--数据运转的催化剂

    原文链接:http://struts2.group.iteye.com/group/wiki/1353-ognl-catalyst-for-data-operation-in-struts2 首先让我 ...

  5. QSerialPort

    (草稿) qt5提供QSerialPort类,封装了串口的api, 可以用这个类写串口通信程序.

  6. c++,operator=

    operator=为什么值得注意? 从语法上讲,下面的程序可以编译通过,我在另一篇笔记示例里面也这样用了. class A1 { public: int operator=(int a)//参数是in ...

  7. C语言宏定义技巧

    出处:http://blog.chinaunix.net/uid-14022540-id-2849095.html 1.宏中"#"和"##"的用法 一.一般用法 ...

  8. [转]svn提交自动同步到web服务器

    参考博文:http://my.oschina.net/wddqing/blog/201567 同步程序思路:用户提交程序到SVN,SVN触发hooks,按不同的hooks进行处理,这里用到的是post ...

  9. 转:onConfigurationChanged的作用

    API原文说明:android:configChangesLists configuration changes that the activity will handle itself. When ...

  10. 基于visual Studio2013解决C语言竞赛题之0701排队输出

     题目 解决代码及点评 #include <stdio.h> #include <stdlib.h> void swap(int *a,int *b) { *a = *a ...