https://www.luogu.org/problem/show?pid=1041

题目背景

近来,一种新的传染病肆虐全球。蓬莱国也发现了零星感染者,为防止该病在蓬莱国大范围流行,该国政府决定不惜一切代价控制传染病的蔓延。不幸的是,由于人们尚未完全认识这种传染病,难以准确判别病毒携带者,更没有研制出疫苗以保护易感人群。于是,蓬莱国的疾病控制中心决定采取切断传播途径的方法控制疾病传播。经过 WHO(世界卫生组织)以及全球各国科研部门的努力,这种新兴传染病的传播途径和控制方法已经研究清楚,剩下的任务就是由你协助蓬莱国疾控中心制定一个有效的控制办法。

题目描述

研究表明,这种传染病的传播具有两种很特殊的性质;

第一是它的传播途径是树型的,一个人X只可能被某个特定的人Y感染,只要Y不得病,或者是XY之间的传播途径被切断,则X就不会得病。

第二是,这种疾病的传播有周期性,在一个疾病传播周期之内,传染病将只会感染一代患者,而不会再传播给下一代。

这些性质大大减轻了蓬莱国疾病防控的压力,并且他们已经得到了国内部分易感人群的潜在传播途径图(一棵树)。但是,麻烦还没有结束。由于蓬莱国疾控中心人手不够,同时也缺乏强大的技术,以致他们在一个疾病传播周期内,只能设法切断一条传播途径,而没有被控制的传播途径就会引起更多的易感人群被感染(也就是与当前已经被感染的人有传播途径相连,且连接途径没有被切断的人群)。当不可能有健康人被感染时,疾病就中止传播。所以,蓬莱国疾控中心要制定出一个切断传播途径的顺序,以使尽量少的人被感染。

你的程序要针对给定的树,找出合适的切断顺序。

输入输出格式

输入格式:

输入格式的第一行是两个整数n(1≤n≤300)和p。接下来p行,每一行有两个整数i和j,表示节点i和j间有边相连(意即,第i人和第j人之间有传播途径相连)。其中节点1是已经被感染的患者。

输出格式:

只有一行,输出总共被感染的人数。

输入输出样例

输入样例#1:

  1. 7 6
  2. 1 2
  3. 1 3
  4. 2 4
  5. 2 5
  6. 3 6
  7. 3 7
输出样例#1:

  1.  
  2. 预处理子树的节点数,爆搜每棵子树,每次跟新出当前最优解
  1. #include <cstdio>
  2. #include <queue>
  3.  
  4. inline void read(int &x)
  5. {
  6. x=; register char ch=getchar();
  7. for(; ch>''||ch<''; ) ch=getchar();
  8. for(; ch>=''&&ch<=''; ch=getchar()) x=x*+ch-'';
  9. }
  10.  
  11. const int N();
  12. int head[N],sumedge;
  13. struct Edge {
  14. int v,next;
  15. Edge(int v=,int next=):v(v),next(next){}
  16. }edge[N<<];
  17. inline void ins(int u,int v)
  18. {
  19. edge[++sumedge]=Edge(v,head[u]);
  20. head[u]=sumedge;
  21. edge[++sumedge]=Edge(u,head[v]);
  22. head[v]=sumedge;
  23. }
  24.  
  25. int size[N],cd[N],dad[N];
  26. void DFS(int u)
  27. {
  28. size[u]=;
  29. for(int v,i=head[u]; i; i=edge[i].next)
  30. {
  31. v=edge[i].v;
  32. if(dad[u]==v) continue;
  33. dad[v]=u; cd[u]++;
  34. DFS(v); size[u]+=size[v];
  35. }
  36. }
  37. bool vis[N];
  38. std::queue<int>que;
  39. void BFS(int s)
  40. {
  41. int ans=;
  42. que.push(s); vis[s]=;
  43. for(int u,v; !que.empty(); )
  44. {
  45. u=que.front(); que.pop();
  46. ans++;
  47. int t1=-,t2=-,t;
  48. for(int i=head[u]; i; i=edge[i].next)
  49. {
  50. v=edge[i].v;
  51. if(vis[v]) continue;
  52. if(cd[v]>t2&&size[v]>=t1)
  53. t2=cd[v],t2=size[v],t=v;
  54. }
  55. for(int i=head[u]; i; i=edge[i].next)
  56. {
  57. v=edge[i].v;
  58. if(vis[v]||v==t) continue;
  59. que.push(v);vis[v]=;
  60. }
  61. }
  62. printf("%d\n",ans);
  63. }
  64.  
  65. int AC()
  66. {
  67. int n,p;
  68. read(n),read(p);
  69. for(int u,v; p--; )
  70. read(u),read(v),ins(u,v);
  71. DFS();
  72. BFS();
  73. return ;
  74. }
  75.  
  76. int Aptal=AC();
  77. int main(){;}

40分贪心,

  1. #include <cstdio>
  2. #include <vector>
  3.  
  4. inline void read(int &x)
  5. {
  6. x=; register char ch=getchar();
  7. for(; ch>''||ch<''; ) ch=getchar();
  8. for(; ch>=''&&ch<=''; ch=getchar()) x=x*+ch-'';
  9. }
  10.  
  11. const int N();
  12. int n,p,ans;
  13. int head[N],sumedge;
  14. struct Edge {
  15. int v,next;
  16. Edge(int v=,int next=):v(v),next(next){}
  17. }edge[N<<];
  18. inline void ins(int u,int v)
  19. {
  20. edge[++sumedge]=Edge(v,head[u]);
  21. head[u]=sumedge;
  22. edge[++sumedge]=Edge(u,head[v]);
  23. head[v]=sumedge;
  24. }
  25.  
  26. #define max(a,b) (a>b?a:b)
  27. std::vector<int>vec[N];
  28. int depth,size[N],dep[N],dad[N];
  29. void Pre(int u)
  30. {
  31. size[u]=;dep[u]=dep[dad[u]]+;
  32. depth=max(depth,dep[u]);
  33. vec[dep[u]].push_back(u);
  34. for(int v,i=head[u]; i; i=edge[i].next)
  35. {
  36. v=edge[i].v;
  37. if(dad[u]==v) continue;
  38. dad[v]=u; Pre(v); size[u]+=size[v];
  39. }
  40. }
  41. bool vis[N];
  42. void pushdown(int u,int x)
  43. {
  44. vis[u]=x;
  45. for(int v,i=head[u]; i; i=edge[i].next)
  46. {
  47. v=edge[i].v;
  48. if(dad[u]!=v) pushdown(v,x);
  49. }
  50. }
  51. void DFS(int u,int sum)
  52. {
  53. ans=ans<(n-sum)?ans:(n-sum);
  54. if(u>depth) return ;
  55. // if(1==size[u]) return ;
  56. for(int i=; i<vec[u].size(); ++i)
  57. {
  58. if(vis[vec[u][i]]) continue;
  59. pushdown(vec[u][i],);
  60. DFS(u+,sum+size[vec[u][i]]);
  61. pushdown(vec[u][i],);
  62. }
  63. }
  64.  
  65. int AC()
  66. {
  67. read(n),read(p); ans=n;
  68. for(int u,v; p--; )
  69. read(u),read(v),ins(u,v);
  70. Pre(); DFS(,);
  71. printf("%d\n",ans);
  72. return ;
  73. }
  74.  
  75. int Aptal=AC();
  76. int main(){;}

AC

洛谷—— P1041 传染病控制的更多相关文章

  1. 洛谷 P1041 传染病控制

    P1041 传染病控制 题目背景 近来,一种新的传染病肆虐全球.蓬莱国也发现了零星感染者,为防止该病在蓬莱国大范围流行,该国政府决定不惜一切代价控制传染病的蔓延.不幸的是,由于人们尚未完全认识这种传染 ...

  2. 洛谷P1041 传染病控制

    解:搜索...... 我们可以每次选择分支少的搜索,或者说,贪心的搜索当前更优的决策. 每一层把能剪的点搞出来,按照度数/SIZ排序,然后依次搜索.加个最优化剪枝就完事了. #include < ...

  3. [NOIP2003] 提高组 洛谷P1041 传染病控制

    题目背景 近来,一种新的传染病肆虐全球.蓬莱国也发现了零星感染者,为防止该病在蓬莱国大范围流行,该国政府决定不惜一切代价控制传染病的蔓延.不幸的是,由于人们尚未完全认识这种传染病,难以准确判别病毒携带 ...

  4. 洛谷 P1041 错解

    P1041 传染病控制 题目背景 近来,一种新的传染病肆虐全球.蓬莱国也发现了零星感染者,为防止该病在蓬莱国大范围流行,该国政府决定不惜一切代价控制传染病的蔓延.不幸的是,由于人们尚未完全认识这种传染 ...

  5. AC日记——传染病控制 洛谷 P1041

    传染病控制 思路: 题目想问的是: 有一棵树: 对于除1外每个深度可以剪掉一棵子树: 问最后剩下多少节点: 题目意思一简单,这个题立马就变水了: 搜索就能ac: 数据有为链的情况,按深度为层次搜索的话 ...

  6. 【noip】跟着洛谷刷noip题

    传送门 1.铺地毯 d1t1 模拟 //Twenty #include<cstdio> #include<cstdlib> #include<iostream> # ...

  7. 洛谷1640 bzoj1854游戏 匈牙利就是又短又快

    bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...

  8. 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.

    没有上司的舞会  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...

  9. 洛谷P1108 低价购买[DP | LIS方案数]

    题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...

随机推荐

  1. P1155 双栈排序(二分图染色)

    P1155 双栈排序(二分图染色) 题目描述 Tom最近在研究一个有趣的排序问题.如图所示,通过2个栈S1和S2,Tom希望借助以下4种操作实现将输入序列升序排序. 操作a 如果输入序列不为空,将第一 ...

  2. bzoj 1556 墓地秘密 —— 状压DP

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1556 预处理出两个障碍四个方向之间的距离(转弯次数),就可以状压DP了: 但预处理很麻烦.. ...

  3. 协议-网络-安全协议:SSH(安全外壳协议)

    ylbtech-协议-网络-安全协议:SSH(安全外壳协议) SSH 为 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定:SSH 为建立 ...

  4. Python 38 sql基础

    数据库服务器中存放的是 库(文件加)  .表(文件) .表里面是记录(一行数据) 增     删     改     查 1.库相关 创建------------------create databa ...

  5. mvc.global.asax事件

    1.global.asax文件概述 global.asax这个文件包含全局应用程序事件的事件处理程序.它响应应用程序级别和会话级别事件的代码. 运行时, Global.asax 将被编译成一个动态生成 ...

  6. ROS-URDF-Gazebo

    前言:在gazebo里运行urdf文件 一.安装教程包 cd ~/catkin_test/srcgit clone https://github.com/ros/urdf_sim_tutorial.g ...

  7. R - Games

    Problem description Manao works on a sports TV. He's spent much time watching the football games of ...

  8. C# html生成PDF遇到的问题,从iTextSharp到wkhtmltopdf

    我们的网站业务会生成一个报告,用网页展示出来,要有生成pdf并下载的功能,关键是生成pdf. 用内容一段段去拼pdf,想想就很崩溃,所以就去网上找直接把html生成pdf的方法. 网上资料大部分都是用 ...

  9. jvm堆外直接内存实现高性能接入层

    jvm堆外直接内存实现高性能接入层https://blog.csdn.net/phil_code/article/details/69056086

  10. SQLServer2008 关于Group by

    如果我们想知道每个国家有多少种水果,那么我们可以通过如下SQL语句来完成: SELECT COUNT(*) FruitName AS 水果种类, ProductPlace AS 出产国 FROM T_ ...