太平王世子事件后,陆小凤成了皇上特聘的御前一品侍卫。

皇宫以午门为起点,直到后宫嫔妃们的寝宫,呈一棵树的形状,某些宫殿间可以互相望见。大内保卫森严,三步一岗,五步一哨,每个宫殿都要有人全天候看守,在不同的宫殿安排看守所需的费用不同。

可是陆小凤手上的经费不足,无论如何也没法在每个宫殿都安置留守侍卫。

帮助陆小凤布置侍卫,在看守全部宫殿的前提下,使得花费的经费最少。

输入格式

输入中数据描述一棵树,描述如下:

第一行 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的更多相关文章

  1. 【题解】保安站岗[P2458]皇宫看守[LOJ10157][SDOI2006]

    [题解]保安站岗[P2458]皇宫看守[LOJ10157][SDOI2006] 传送门:皇宫看守\([LOJ10157]\) 保安站岗 \([P2458]\) \([SDOI2006]\) [题目描述 ...

  2. LOJ10157——皇宫看守(树形DP)

    传送门:QAQQAQ 题意:在一个树上放置守卫,使每一个节点都至少有相邻一节点放置守卫,使最终经费最少 思路:树形DP 首先会想到没有上司的舞会,0表示不放守卫,1表示放守卫,但考虑到对于当前点不放守 ...

  3. $Loj10157$ 皇宫看守 树形$DP$

    loj Description 有一些宫殿,它们呈树形结构,相邻的宫殿之间可以互相望见.在一些宫殿设立士兵,使得所有的宫殿都有士兵或是被士兵望见.求最小士兵数. Sol 状态: f[x][0] 表示结 ...

随机推荐

  1. 多维数组遍历.php

    $a=array('fruits'=>array('a'=>'orange','b'=>'grape','c'=>'apple'),     'numbers'=>arr ...

  2. 关闭layer

    function closeBox() { var index = parent.layer.getFrameIndex(window.name); //获取当前窗体索引 parent.layer.c ...

  3. 浅入kubernetes(2):Kubernetes 的组成

    目录 说明 Kubernetes集群的组成 What are containerized applications? What are Kubernetes containers? What are ...

  4. linux security module机制

    linux security module机制 概要 Hook机制,linux MAC的通用框架,可以使用SElinux, AppArmor,等作为不同安全框架的实现

  5. shell脚本学习之6小时搞定(1)

    shell脚本学习之6小时搞定(1) 简介 Shell是一种脚本语言,那么,就必须有解释器来执行这些脚本. Unix/Linux上常见的Shell脚本解释器有bash.sh.csh.ksh等,习惯上把 ...

  6. DHCP.md

    DHCP 主配置文件   从 /usr/share/doc/dhcp 复制 dhcpd.conf.sample 到/etc/dhcp下                                  ...

  7. idea中文注释出现乱码,我靠自己解决了

    如果你像我一样️,查遍google百度,半天下来还是找不到解决方案,说不定这篇博客能帮助你顺利解决呢 好了,那么开始说说我是怎么解决麻烦的. 首先,我想打开一份java文稿.光预览,它是没有任何问题的 ...

  8. python学习笔记 | wordcloud安装指南

    问题: 直接在命令行输入: pip install wordcloud 不出意外,直接报错,显示缺失vc*****.bat,意思是缺失vc版本,这个安装方式基本可以扔掉. 解决: http://t.c ...

  9. 2.jmeter组件介绍

    jmeter默认语言设置:  1.临时设置: 进入options -- Choose Language -- 选择中文简体,设置后语言  切换成中文,重启失效  2.永久设置:进入jmeter目录下的 ...

  10. kubernets之pod简介

    一  k8s集群里面的最小单位是pod 1.1 一个较为简单的pod的配置文件 apiverson: api的版本号 kind: 资源的种类 metadata: pod的种类等相关信息 spec: p ...