1. 问题描述:

太平王世子事件后,陆小凤成了皇上特聘的御前一品侍卫。皇宫各个宫殿的分布,呈一棵树的形状,宫殿可视为树中结点,两个宫殿之间如果存在道路直接相连,则该道路视为树中的一条边。已知,在一个宫殿镇守的守卫不仅能够观察到本宫殿的状况,还能观察到与该宫殿直接存在道路相连的其他宫殿的状况。大内保卫森严,三步一岗,五步一哨,每个宫殿都要有人全天候看守,在不同的宫殿安排看守所需的费用不同。可是陆小凤手上的经费不足,无论如何也没法在每个宫殿都安置留守侍卫。帮助陆小凤布置侍卫,在看守全部宫殿的前提下,使得花费的经费最少。

输入格式

输入中数据描述一棵树,描述如下:第一行 n,表示树中结点的数目。第二行至第 n+1 行,每行描述每个宫殿结点信息,依次为:该宫殿结点标号 i,在该宫殿安置侍卫所需的经费 k,该结点的子结点数 m,接下来 m 个数,分别是这个结点的 m 个子结点的标号 r1,r2,…,rm。对于一个 n 个结点的树,结点标号在 1 到 n 之间,且标号不重复。

输出格式

输出一个整数,表示最少的经费。

数据范围

1 ≤ n ≤ 1500

输入样例:

6
1 30 3 2 3 4
2 16 2 5 6
3 5 0
4 4 0
5 11 0
6 5 0

输出样例:

25

样例解释:
在2、3、4结点安排护卫,可以观察到全部宫殿,所需经费最少,为 16 + 5 + 4 = 25。
来源:https://www.acwing.com/problem/content/description/1079/

2. 思路分析:

分析题目可以知道这道题目实际上求解的是能够覆盖所有的点的最小花费,注意与323题战略游戏的区别,323题需要求解覆盖所有的边的最小花费,也即一条边中至少需要一个点来覆盖,只需要两个状态即可解决,dp[u][0]表示不选当前根节点u的最小花费,dp[u][1]表示选当前根节点u的最小花费,分两种情况讨论即可;而这道题目对于当前的根节点u其实是受到三种情况的影响,分别是子节点,父节点和自己(每一种情况对应不同的守卫情况),所以第二维使用两个状态已经不能够表示当前的所有状态,这里需要三个状态来表示所有可能的状态,对应的状态表示的含义如下:

  • dp[u][0]表示u这个节点没有放置守卫并且被父节点看到的所有方案的最小花费
  • dp[u][1]表示u这个节点没有放置守卫并且被子节点看到的所有方案的最小花费
  • dp[u][2]表示u这个节点放置了守卫的所有方案的最小花费

当前的u作为根节点;对于dp[u][0]是以当前的节点u作为根节点的最小花费,我们只需要考虑子节点的影响即可,因为在递归返回到上一层的时候(回溯)会更新到父节点放守卫的情况(当前节点的父节点一定会放置一个守卫从而返回到上一层的时候会使用这个状态进行更新),因为是父节点看到了当前的节点u,所以u的子节点可以放也可以不放守卫(不考虑子节点受到父节点影响的情况),对于这两种情况取一个min累加到当前的dp[u][0]上即可;对于dp[u][2]表示当前的节点u放置了守卫,我们也只需要考虑子节点的情况即可,子节点可以放也可以不放;对于dp[u][1]比较麻烦我们需要枚举所有看到当前u的子节点k并且需要加上其余节点可放也可以不放的情况,我们可以在枚举u的子节点递归回溯的时候计算出所有子节点可放可不放的情况的总和s,使用s减去当前的可以看到当前节点u的最小花费就是除了当前节点k之外所有子节点的花费,枚举所有的子节点取一个min就是当前的dp[u][1],其实表示的是至少存在一个u的子节点能够看到u。

3. 代码如下:

from typing import List
import sys
# 设置递归的最大调用次数, 如果不设置会出现爆栈的问题, python3的最大递归调用次数在1000次左右
sys.setrecursionlimit(1600)class Solution:def dfs(self, u: int, w: List[int], g: List[List[int]], dp: List[List[int]]):# 当前的根节点u表示放置了守卫所以一开始的权重为当前节点的权重dp[u][2] = w[u]s = 0# 先计算dp[u][0]和dp[u][2]这两个可以直接计算出结果for next in g[u]:self.dfs(next, w, g, dp)dp[u][0] += min(dp[next][1], dp[next][2])dp[u][2] += min(dp[next][0], dp[next][1], dp[next][2])# 计算s, 为后面计算dp[u][1]做准备s += min(dp[next][1], dp[next][2])dp[u][1] = 10 ** 9# 计算dp[u][1]for next in g[u]:# 枚举当前的子节点能够看到父节点的情况, 没有所有的子节点取一个mindp[u][1] = min(dp[u][1], min(dp[u][1], s - min(dp[next][1], dp[next][2]) + dp[next][2]))def process(self):n = int(input())# sta表示标记不是根节点的sta = [0] * (n + 1)# g的每一个元素都是一个列表可以用来存储当前节点的所有子节点编号g = [list() for i in range(n + 1)]w = [0] * (n + 1)for i in range(n):t = list(map(int, input().split()))a, c = t[0], t[1]w[a] = cif t[2]:# 由输入可以知道这是一个有向图, 所以存储一个一条边即可for j in range(3, len(t)):b = t[j]g[a].append(b)# 标记不是叶节点的节点sta[b] = 1# 第二维存在三个状态dp = [[0] * 3 for i in range(n + 1)]root = 1# 找到根节点while sta[root]: root += 1self.dfs(root, w, g, dp)# 以当前的root作为根节点能够被子节点看到和自身看到的较小值就是答案, 根节点是不能够被父节点看到的return min(dp[root][1], dp[root][2])if __name__ == "__main__":print(Solution().process())

1077 皇宫看守(树形dp)相关推荐

  1. AcWing1077. 皇宫看守(树形DP)题解

    题目传送门 题目描述 太平王世子事件后,陆小凤成了皇上特聘的御前一品侍卫. 皇宫以午门为起点,直到后宫嫔妃们的寝宫,呈一棵树的形状,某些宫殿间可以互相望见. 大内保卫森严,三步一岗,五步一哨,每个宫殿 ...

  2. AcWing 1077. 皇宫看守(树形DP + 状态机DP)

    AcWing 1077. 皇宫看守(树形DP + 状态机DP) 一.问题 二.分析 1.思路分析 2.状态表示 3.状态转移 4.循环设计 5.初末状态 三.代码 一.问题 二.分析 1.思路分析 在 ...

  3. Acwing 1077.皇宫看守

    Acwing 1077.皇宫看守 题目 输入格式 输出格式 数据范围 输入样例 输出样例 样例解释 分析 详细代码 这是我第一篇博客,如有侵权或者不足的地方,我将予以修改,并改正 题目 太平王世子事件 ...

  4. Acwing 1077. 皇宫看守

    参考题目:Acwing 1077. 皇宫看守 题意 给定一个树,求覆盖所有点的最少花费. 算法:树形DP 时间复杂度: O ( n ) O(n) O(n) (每个点只被搜索一次) f 数组含义: f[ ...

  5. 1077. 皇宫看守

    太平王世子事件后,陆小凤成了皇上特聘的御前一品侍卫. 皇宫各个宫殿的分布,呈一棵树的形状,宫殿可视为树中结点,两个宫殿之间如果存在道路直接相连,则该道路视为树中的一条边. 已知,在一个宫殿镇守的守卫不 ...

  6. AcWing 1077. 皇宫看守(详解)

    题目描述 太平王世子事件后,陆小凤成了皇上特聘的御前一品侍卫.皇宫各个宫殿的分布,呈一棵树的形状,宫殿可视为树中结点,两个宫殿之间如果存在道路直接相连,则该道路视为树中的一条边.已知,在一个宫殿镇守的 ...

  7. 树形dp day43

    虽然已经很困了 但还是想起标题没取 就来写一下今天的鲜花 话说最近天气真热啊 好多时候都不想出去玩qwq 今天想到了一个很好玩的标题<由于找不到暑假工 所以只好来打休闲ACM> 休闲感觉称 ...

  8. 1579: 【例 5】皇宫看守(最小支配集——贪心求解/树形DP)

    [题目描述] 太平王世子事件后,陆小凤成了皇上特聘的御前一品侍卫. 皇宫以午门为起点,直到后宫嫔妃们的寝宫,呈一棵树的形状,某些宫殿间可以互相望见.大内保卫森严,三步一岗,五步一哨,每个宫殿都要有人全 ...

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

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

  10. 【树形dp】vijos1144小胖守皇宫

    细节很精妙 描述 huyichen世子事件后,xuzhenyi成了皇上特聘的御前一品侍卫. 皇宫以午门为起点,直到后宫嫔妃们的寝宫,呈一棵树的形状:某些宫殿间可以互相望见.大内保卫森严,三步一岗,五步 ...

最新文章

  1. SAP MM PR Release Strategy 配置中Classification数据的维护
  2. Google Code Jam 2014 总结
  3. Sentinel: 分布式系统的流量防卫兵 1
  4. C#开发的高性能EXCEL导入、导出工具DataPie(支持MSSQL、ORACLE、ACCESS,附源码下载地址)...
  5. Docker上安装jenkins让持续集成飞
  6. 你所不了解的五条面试忠告
  7. Python开发——安装requests第三方库
  8. 轻量化网络:SqueezeNext
  9. tips of MIPS
  10. Bean的装配方式之xml装配--(超详细,适合小白入门)
  11. 如何在酷狗上下载付费歌曲
  12. UML类图中各种箭头和线条的含义和用法
  13. 简单的 C/C++ 项目自动化构建--Xmake
  14. spark.jars.packages使用镜像源加速
  15. 2022年春招美团二面总结 凉经
  16. 测试工程师如何提升自己
  17. 安卓apk安装包腾讯云-乐固加固以及重新签名
  18. HAL库自学笔记#2【PWM】
  19. ORA-03113 end-of-file on communication channel 问题解决
  20. 增长:IT运维发展趋势报告

热门文章

  1. 浙大计算机科学与技术专业考研科目,浙大考研多少分过初试计算机科学与技术专业...
  2. 为什么宁可提拔一个新同事当领导,也不提拔我这个十年的老员工呢?
  3. [附源码]计算机毕业设计JAVA龙虎时代健身房管理系统
  4. c++ 原子操作 赋值_C++11 多线程中原子类型与原子操作
  5. python数据字典ppt_python数据字典的操作
  6. 国内营商环境测评指标简介——国家级、省市级和民间指标比较分析
  7. 员工的成长之路离不开计划和绩效分析
  8. 动画原理:3D贪吃蛇游戏制作(OpenGL)
  9. 将色彩鲜艳的照片变成偏黑白的淡彩特效
  10. 风雪一隅 php,科学网-不谋全局者不足谋一隅-肖建华的博文