博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
洛谷P2016——战略游戏(树形)
阅读量:5228 次
发布时间:2019-06-14

本文共 1368 字,大约阅读时间需要 4 分钟。

描述

Bob喜欢玩电脑游戏,特别是战略游戏。但是他经常无法找到快速玩过游戏的办法。现在他有个问题。
他要建立一个古城堡,城堡中的路形成一棵树。他要在这棵树的结点上放置最少数目的士兵,使得这些士兵能了望到所有的路。
注意,某个士兵在一个结点上时,与该结点相连的所有边将都可以被了望到。
请你编一程序,给定一树,帮Bob计算出他需要放置最少的士兵.
输入
第一行 N,表示树中结点的数目。
第二行至第N+1行,每行描述每个结点信息,依次为:该结点标号i,k(后面有k条边与结点I相连)。
接下来k个数,分别是每条边的另一个结点标号r1,r2,…,rk。
对于一个n(0<n<=1500)个结点的树,结点标号在0到n-1之间,在输入数据中每条边只出现一次。
输出
输出文件仅包含一个数,为所求的最少的士兵数目
样例输入
4
0 1 1
1 2 2 3
2 0
3 0
样例输出
1

考虑到一个点会被其子节点影响

所以f[i][j]f[i][j]f[i][j]表示点iii为根的子树,选还是不选的最小数量,就只需要枚举子节点就可以了

#include
using namespace std;inline int read(){
char ch=getchar(); int res=0,f=1; while(!isdigit(ch)){
if(ch=='-')f=-1;ch=getchar();} while(isdigit(ch))res=(res<<3)+(res<<1)+(ch^48),ch=getchar(); return res*f;}const int N=1505;int n,adj[N],dep[N],nxt[N<<1],to[N<<1],a[N],f[N][2],cnt,maxn,root;inline void addedge(int u,int v){
nxt[++cnt]=adj[u],adj[u]=cnt,to[cnt]=v;}inline void dfs(int u,int fa){
f[u][1]=1; for(int e=adj[u];e;e=nxt[e]){
int v=to[e]; if(v==fa)continue; dfs(v,u); f[u][1]+=min(f[v][0],f[v][1]); f[u][0]+=f[v][1]; }}int main(){
n=read(); for(int i=1;i<=n;i++){
int u=read()+1,k=read(); for(int i=1;i<=k;i++){
int v=read()+1;addedge(u,v),addedge(v,u); } } dfs(1,0); cout<

转载于:https://www.cnblogs.com/stargazer-cyk/p/10366414.html

你可能感兴趣的文章
监控工具之---Prometheus 安装详解(三)
查看>>
不错的MVC文章
查看>>
IOS Google语音识别更新啦!!!
查看>>
[置顶] Linux终端中使用上一命令减少键盘输入
查看>>
BootScrap
查看>>
路冉的JavaScript学习笔记-2015年1月23日
查看>>
Mysql出现(10061)错误提示的暴力解决办法
查看>>
2018-2019-2 网络对抗技术 20165202 Exp3 免杀原理与实践
查看>>
NPM慢怎么办 - nrm切换资源镜像
查看>>
Swift - UIView的常用属性和常用方法总结
查看>>
Swift - 异步加载各网站的favicon图标,并在单元格中显示
查看>>
【Python学习笔记】1.基础知识
查看>>
梦断代码阅读笔记02
查看>>
selenium学习中遇到的问题
查看>>
大数据学习之一——了解简单概念
查看>>
Linux升级内核教程(CentOS7)
查看>>
Lintcode: Partition Array
查看>>
类别的三个作用
查看>>
Maximum Product Subarray
查看>>
[转载] MySQL的四种事务隔离级别
查看>>