NC19810kingdom(dp)是什么?
- 内容介绍
- 文章标签
- 相关推荐
本文共计692个文字,预计阅读时间需要3分钟。
无法触及的一题,蕴含着深刻的感受,但首先是题目所给信息的优先观察。应采用平方法则逐步剖析,我仅能联想到推断子女大小这一思路。后来看了解题,发现他们把信息拓展得更深。
想不到的一道题,有点背包的感觉,但是重点还是题目所给的信息首先观察题目应该是平方算法进一步剖析,我只能想到枚举重儿子大小这个思路。后来看了题解发现他们把信息挖掘的很到位。重儿子肯定想不到的一道题,有点背包的感觉,但是重点还是题目所给的信息
首先观察题目应该是平方算法
进一步剖析,我只能想到枚举重儿子大小这个思路。
后来看了题解发现他们把信息挖掘的很到位。重儿子肯定是要枚举
现在求的是最大代价,而除了重儿子外,自顶向下的思路上看,还有很多其他子树,这些树组成了森林
如果求他的最大代价比较关键,题目其实没啥信息,有的比如节点个数,最大是平方算法,其他儿子不能大于所选的重儿子,所以把这些信息结合起来产生了一种状态设计f[i][j]
表示以i个节点,最大的子树个数不超过j的森林的最大代价。
这样就可以枚举更新了,而这个dp,因为是最大,所以首先要从f[i][j-1]更新过来,因为子状态包括他,其次就要考虑节点个数的变化
那么这个森林的更新就可以枚举,用ans[j]+f[i-j][j]这样的状态去更新,因为森林肯定是很多树,我们枚举其中一棵树的大小,那么其他树仍然组成了一个森林,并且因为这是小状态所以已经被计算了。
本文共计692个文字,预计阅读时间需要3分钟。
无法触及的一题,蕴含着深刻的感受,但首先是题目所给信息的优先观察。应采用平方法则逐步剖析,我仅能联想到推断子女大小这一思路。后来看了解题,发现他们把信息拓展得更深。
想不到的一道题,有点背包的感觉,但是重点还是题目所给的信息首先观察题目应该是平方算法进一步剖析,我只能想到枚举重儿子大小这个思路。后来看了题解发现他们把信息挖掘的很到位。重儿子肯定想不到的一道题,有点背包的感觉,但是重点还是题目所给的信息
首先观察题目应该是平方算法
进一步剖析,我只能想到枚举重儿子大小这个思路。
后来看了题解发现他们把信息挖掘的很到位。重儿子肯定是要枚举
现在求的是最大代价,而除了重儿子外,自顶向下的思路上看,还有很多其他子树,这些树组成了森林
如果求他的最大代价比较关键,题目其实没啥信息,有的比如节点个数,最大是平方算法,其他儿子不能大于所选的重儿子,所以把这些信息结合起来产生了一种状态设计f[i][j]
表示以i个节点,最大的子树个数不超过j的森林的最大代价。
这样就可以枚举更新了,而这个dp,因为是最大,所以首先要从f[i][j-1]更新过来,因为子状态包括他,其次就要考虑节点个数的变化
那么这个森林的更新就可以枚举,用ans[j]+f[i-j][j]这样的状态去更新,因为森林肯定是很多树,我们枚举其中一棵树的大小,那么其他树仍然组成了一个森林,并且因为这是小状态所以已经被计算了。

