洛谷—— P1041 传染病控制
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是已经被感染的患者。
输出格式:
只有一行,输出总共被感染的人数。
输入输出样例
- 7 6
- 1 2
- 1 3
- 2 4
- 2 5
- 3 6
- 3 7
- 3
- 预处理子树的节点数,爆搜每棵子树,每次跟新出当前最优解
- #include <cstdio>
- #include <queue>
- inline void read(int &x)
- {
- x=; register char ch=getchar();
- for(; ch>''||ch<''; ) ch=getchar();
- for(; ch>=''&&ch<=''; ch=getchar()) x=x*+ch-'';
- }
- const int N();
- int head[N],sumedge;
- struct Edge {
- int v,next;
- Edge(int v=,int next=):v(v),next(next){}
- }edge[N<<];
- inline void ins(int u,int v)
- {
- edge[++sumedge]=Edge(v,head[u]);
- head[u]=sumedge;
- edge[++sumedge]=Edge(u,head[v]);
- head[v]=sumedge;
- }
- int size[N],cd[N],dad[N];
- void DFS(int u)
- {
- size[u]=;
- for(int v,i=head[u]; i; i=edge[i].next)
- {
- v=edge[i].v;
- if(dad[u]==v) continue;
- dad[v]=u; cd[u]++;
- DFS(v); size[u]+=size[v];
- }
- }
- bool vis[N];
- std::queue<int>que;
- void BFS(int s)
- {
- int ans=;
- que.push(s); vis[s]=;
- for(int u,v; !que.empty(); )
- {
- u=que.front(); que.pop();
- ans++;
- int t1=-,t2=-,t;
- for(int i=head[u]; i; i=edge[i].next)
- {
- v=edge[i].v;
- if(vis[v]) continue;
- if(cd[v]>t2&&size[v]>=t1)
- t2=cd[v],t2=size[v],t=v;
- }
- for(int i=head[u]; i; i=edge[i].next)
- {
- v=edge[i].v;
- if(vis[v]||v==t) continue;
- que.push(v);vis[v]=;
- }
- }
- printf("%d\n",ans);
- }
- int AC()
- {
- int n,p;
- read(n),read(p);
- for(int u,v; p--; )
- read(u),read(v),ins(u,v);
- DFS();
- BFS();
- return ;
- }
- int Aptal=AC();
- int main(){;}
40分贪心,
- #include <cstdio>
- #include <vector>
- inline void read(int &x)
- {
- x=; register char ch=getchar();
- for(; ch>''||ch<''; ) ch=getchar();
- for(; ch>=''&&ch<=''; ch=getchar()) x=x*+ch-'';
- }
- const int N();
- int n,p,ans;
- int head[N],sumedge;
- struct Edge {
- int v,next;
- Edge(int v=,int next=):v(v),next(next){}
- }edge[N<<];
- inline void ins(int u,int v)
- {
- edge[++sumedge]=Edge(v,head[u]);
- head[u]=sumedge;
- edge[++sumedge]=Edge(u,head[v]);
- head[v]=sumedge;
- }
- #define max(a,b) (a>b?a:b)
- std::vector<int>vec[N];
- int depth,size[N],dep[N],dad[N];
- void Pre(int u)
- {
- size[u]=;dep[u]=dep[dad[u]]+;
- depth=max(depth,dep[u]);
- vec[dep[u]].push_back(u);
- for(int v,i=head[u]; i; i=edge[i].next)
- {
- v=edge[i].v;
- if(dad[u]==v) continue;
- dad[v]=u; Pre(v); size[u]+=size[v];
- }
- }
- bool vis[N];
- void pushdown(int u,int x)
- {
- vis[u]=x;
- for(int v,i=head[u]; i; i=edge[i].next)
- {
- v=edge[i].v;
- if(dad[u]!=v) pushdown(v,x);
- }
- }
- void DFS(int u,int sum)
- {
- ans=ans<(n-sum)?ans:(n-sum);
- if(u>depth) return ;
- // if(1==size[u]) return ;
- for(int i=; i<vec[u].size(); ++i)
- {
- if(vis[vec[u][i]]) continue;
- pushdown(vec[u][i],);
- DFS(u+,sum+size[vec[u][i]]);
- pushdown(vec[u][i],);
- }
- }
- int AC()
- {
- read(n),read(p); ans=n;
- for(int u,v; p--; )
- read(u),read(v),ins(u,v);
- Pre(); DFS(,);
- printf("%d\n",ans);
- return ;
- }
- int Aptal=AC();
- int main(){;}
AC
洛谷—— P1041 传染病控制的更多相关文章
- 洛谷 P1041 传染病控制
P1041 传染病控制 题目背景 近来,一种新的传染病肆虐全球.蓬莱国也发现了零星感染者,为防止该病在蓬莱国大范围流行,该国政府决定不惜一切代价控制传染病的蔓延.不幸的是,由于人们尚未完全认识这种传染 ...
- 洛谷P1041 传染病控制
解:搜索...... 我们可以每次选择分支少的搜索,或者说,贪心的搜索当前更优的决策. 每一层把能剪的点搞出来,按照度数/SIZ排序,然后依次搜索.加个最优化剪枝就完事了. #include < ...
- [NOIP2003] 提高组 洛谷P1041 传染病控制
题目背景 近来,一种新的传染病肆虐全球.蓬莱国也发现了零星感染者,为防止该病在蓬莱国大范围流行,该国政府决定不惜一切代价控制传染病的蔓延.不幸的是,由于人们尚未完全认识这种传染病,难以准确判别病毒携带 ...
- 洛谷 P1041 错解
P1041 传染病控制 题目背景 近来,一种新的传染病肆虐全球.蓬莱国也发现了零星感染者,为防止该病在蓬莱国大范围流行,该国政府决定不惜一切代价控制传染病的蔓延.不幸的是,由于人们尚未完全认识这种传染 ...
- AC日记——传染病控制 洛谷 P1041
传染病控制 思路: 题目想问的是: 有一棵树: 对于除1外每个深度可以剪掉一棵子树: 问最后剩下多少节点: 题目意思一简单,这个题立马就变水了: 搜索就能ac: 数据有为链的情况,按深度为层次搜索的话 ...
- 【noip】跟着洛谷刷noip题
传送门 1.铺地毯 d1t1 模拟 //Twenty #include<cstdio> #include<cstdlib> #include<iostream> # ...
- 洛谷1640 bzoj1854游戏 匈牙利就是又短又快
bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...
- 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.
没有上司的舞会 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...
- 洛谷P1108 低价购买[DP | LIS方案数]
题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...
随机推荐
- P1155 双栈排序(二分图染色)
P1155 双栈排序(二分图染色) 题目描述 Tom最近在研究一个有趣的排序问题.如图所示,通过2个栈S1和S2,Tom希望借助以下4种操作实现将输入序列升序排序. 操作a 如果输入序列不为空,将第一 ...
- bzoj 1556 墓地秘密 —— 状压DP
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1556 预处理出两个障碍四个方向之间的距离(转弯次数),就可以状压DP了: 但预处理很麻烦.. ...
- 协议-网络-安全协议:SSH(安全外壳协议)
ylbtech-协议-网络-安全协议:SSH(安全外壳协议) SSH 为 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定:SSH 为建立 ...
- Python 38 sql基础
数据库服务器中存放的是 库(文件加) .表(文件) .表里面是记录(一行数据) 增 删 改 查 1.库相关 创建------------------create databa ...
- mvc.global.asax事件
1.global.asax文件概述 global.asax这个文件包含全局应用程序事件的事件处理程序.它响应应用程序级别和会话级别事件的代码. 运行时, Global.asax 将被编译成一个动态生成 ...
- ROS-URDF-Gazebo
前言:在gazebo里运行urdf文件 一.安装教程包 cd ~/catkin_test/srcgit clone https://github.com/ros/urdf_sim_tutorial.g ...
- R - Games
Problem description Manao works on a sports TV. He's spent much time watching the football games of ...
- C# html生成PDF遇到的问题,从iTextSharp到wkhtmltopdf
我们的网站业务会生成一个报告,用网页展示出来,要有生成pdf并下载的功能,关键是生成pdf. 用内容一段段去拼pdf,想想就很崩溃,所以就去网上找直接把html生成pdf的方法. 网上资料大部分都是用 ...
- jvm堆外直接内存实现高性能接入层
jvm堆外直接内存实现高性能接入层https://blog.csdn.net/phil_code/article/details/69056086
- SQLServer2008 关于Group by
如果我们想知道每个国家有多少种水果,那么我们可以通过如下SQL语句来完成: SELECT COUNT(*) FruitName AS 水果种类, ProductPlace AS 出产国 FROM T_ ...