loj10157
太平王世子事件后,陆小凤成了皇上特聘的御前一品侍卫。
皇宫以午门为起点,直到后宫嫔妃们的寝宫,呈一棵树的形状,某些宫殿间可以互相望见。大内保卫森严,三步一岗,五步一哨,每个宫殿都要有人全天候看守,在不同的宫殿安排看守所需的费用不同。
可是陆小凤手上的经费不足,无论如何也没法在每个宫殿都安置留守侍卫。
帮助陆小凤布置侍卫,在看守全部宫殿的前提下,使得花费的经费最少。
输入格式
输入中数据描述一棵树,描述如下:
第一行 n,表示树中结点的数目。
第二行至第 n+1行,每行描述每个宫殿结点信息,依次为:该宫殿结点标号 i(0<i≤n),在该宫殿安置侍卫所需的经费 k,该边的儿子数 m,接下来 m 个数,分别是这个节点的 m 个儿子的标号r1,r2,⋯,rm。
对于一个 n 个结点的树,结点标号在 1 到 n 之间,且标号不重复。
输出格式
输出最少的经费
数据范围与提示
对于 100% 的数据,0<n≤1500。
______________________________________________________________________________________________________________________
f[u][0]:u点由父节点看守
f[u][1]:u点由子节点看守
f[u][2]:u点由自己看守
f[u][0]=sum(min(f[v][1],f[v][2]))
f[u][2]=sum(min(f[v][0],f[v][1],f[v][2]))+fy[u]
f[u][1]=sum(min(f[v][1],f[v][2]))+min(f[v][2]-min(f[v][1],f[v][2]))
注意f[u][1]的推导
______________________________________________________________________________________________________________________
1 #include<bits/stdc++.h>
2 using namespace std;
3 const int maxn=1510;
4 int n,root;
5 int fy[maxn],rd[maxn];
6 struct edge
7 {
8 int u,v,nxt;
9 }e[maxn];
10 int head[maxn],js;
11 void addage(int u,int v)
12 {
13 e[++js].u=u;e[js].v=v;
14 e[js].nxt=head[u];head[u]=js;
15 }
16 int f[maxn][3];
17 int minn(int a,int b,int c)
18 {
19 int tp=a;
20 if(tp>b)tp=b;
21 if(tp>c)tp=c;
22 return tp;
23 }
24 void dp(int u,int fa)
25 {
26 f[u][0]=f[u][1]=0;
27 f[u][2]=fy[u];
28 int tp=0x7fffffff;
29 for(int i=head[u];i;i=e[i].nxt)
30 {
31 int v=e[i].v;
32 dp(v,u);
33 f[u][0]+=min(f[v][1],f[v][2]);
34 f[u][2]+=minn(f[v][0],f[v][1],f[v][2]);
35 f[u][1]+=min(f[v][1],f[v][2]);
36 tp=min(tp,f[v][2]-min(f[v][1],f[v][2]));
37 }
38 f[u][1]+=tp;
39 }
40 int main()
41 {
42 scanf("%d",&n);
43 for(int u,nm,v,i=1;i<=n;++i)
44 {
45 scanf("%d",&u);
46 scanf("%d%d",&fy[u],&nm);
47 for(int j=0;j<nm;++j)
48 {
49 scanf("%d",&v);
50 rd[v]++;
51 addage(u,v);
52 }
53 }
54 for(int i=1;i<=n;++i)
55 {
56 if(rd[i]==0)
57 {
58 root=i;
59 break;
60 }
61 }
62 dp(root,0);
63 cout<<min(f[root][1],f[root][2]);
64 return 0;
65 }
loj10157的更多相关文章
- 【题解】保安站岗[P2458]皇宫看守[LOJ10157][SDOI2006]
[题解]保安站岗[P2458]皇宫看守[LOJ10157][SDOI2006] 传送门:皇宫看守\([LOJ10157]\) 保安站岗 \([P2458]\) \([SDOI2006]\) [题目描述 ...
- LOJ10157——皇宫看守(树形DP)
传送门:QAQQAQ 题意:在一个树上放置守卫,使每一个节点都至少有相邻一节点放置守卫,使最终经费最少 思路:树形DP 首先会想到没有上司的舞会,0表示不放守卫,1表示放守卫,但考虑到对于当前点不放守 ...
- $Loj10157$ 皇宫看守 树形$DP$
loj Description 有一些宫殿,它们呈树形结构,相邻的宫殿之间可以互相望见.在一些宫殿设立士兵,使得所有的宫殿都有士兵或是被士兵望见.求最小士兵数. Sol 状态: f[x][0] 表示结 ...
随机推荐
- 多维数组遍历.php
$a=array('fruits'=>array('a'=>'orange','b'=>'grape','c'=>'apple'), 'numbers'=>arr ...
- 关闭layer
function closeBox() { var index = parent.layer.getFrameIndex(window.name); //获取当前窗体索引 parent.layer.c ...
- 浅入kubernetes(2):Kubernetes 的组成
目录 说明 Kubernetes集群的组成 What are containerized applications? What are Kubernetes containers? What are ...
- linux security module机制
linux security module机制 概要 Hook机制,linux MAC的通用框架,可以使用SElinux, AppArmor,等作为不同安全框架的实现
- shell脚本学习之6小时搞定(1)
shell脚本学习之6小时搞定(1) 简介 Shell是一种脚本语言,那么,就必须有解释器来执行这些脚本. Unix/Linux上常见的Shell脚本解释器有bash.sh.csh.ksh等,习惯上把 ...
- DHCP.md
DHCP 主配置文件 从 /usr/share/doc/dhcp 复制 dhcpd.conf.sample 到/etc/dhcp下 ...
- idea中文注释出现乱码,我靠自己解决了
如果你像我一样️,查遍google百度,半天下来还是找不到解决方案,说不定这篇博客能帮助你顺利解决呢 好了,那么开始说说我是怎么解决麻烦的. 首先,我想打开一份java文稿.光预览,它是没有任何问题的 ...
- python学习笔记 | wordcloud安装指南
问题: 直接在命令行输入: pip install wordcloud 不出意外,直接报错,显示缺失vc*****.bat,意思是缺失vc版本,这个安装方式基本可以扔掉. 解决: http://t.c ...
- 2.jmeter组件介绍
jmeter默认语言设置: 1.临时设置: 进入options -- Choose Language -- 选择中文简体,设置后语言 切换成中文,重启失效 2.永久设置:进入jmeter目录下的 ...
- kubernets之pod简介
一 k8s集群里面的最小单位是pod 1.1 一个较为简单的pod的配置文件 apiverson: api的版本号 kind: 资源的种类 metadata: pod的种类等相关信息 spec: p ...