遇到个动态规划问题,求大佬康康

#算法工程师##C/C++#
全部评论
别慌,DP先考虑状态再考虑转移就行。 首先考虑下如何表示状态。 显然的我们得表示出那些星星被销毁了那些没有。2^n的表示法自然是最简单的,但是肯定无法按时跑出来。因此我们得考虑简化一下。 由于只有相邻的星星才能合并,所以其实我们的状态只要能表达出哪些星星相邻即可。因此,我选择(i,j)来表示第i个星星和第j个星星之间的星星被消除掉了,以及f(i,j)是消除它们能得到的最大得分。 然后我们需要考虑如何转移,对于(i,j),我们只需要知道最后被消除的a是谁就行。根据f(X,X)的定义,之前被消除可以获得最大分数就是f(i,a)+f(a,j),至于具体怎么个消除顺序我不关心。而消除a的得分是与它相邻的两个星星乘积,即:S[i]*S[j]。故此,我们有: f(i,j)=for a max( f(i,a)+f(a,j)+S[i]*S[j]  ) 然后我们将伪代码转成C支持的格式 F[i][j]=for (int a=i+1;a<j;++a) F[i][j]=max(F[i][j],F[i][a]+F[a][j]+S[i]*S[j]) 最后只剩下两个星星,而且只能是首尾星星,所以结果即为F[0][n-1] 然后我们需要处理下空间复用以及遍历顺序的问题: 空间方面,由于F[a][j]同时被F[0..a][j]依赖,不是一次性的,不能压成一围 遍历顺序方面,由于F[i,a]、F[a,j]必须在F[i,j]之前计算,所以需要安排一下顺序,例如:For (j=n-1;j>=0;--j) for (i=0;i<j;++i); 最后需要处理下边界值以及初始值。略
1 回复 分享
发布于 2020-06-08 12:05
区间dp,dp[i][j]表示消除范围(i, j)的最大得分,答案是dp[0][n-1]
点赞 回复 分享
发布于 2020-06-08 10:52

相关推荐

评论
点赞
1
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
10113次浏览 92人参与
# 你的实习产出是真实的还是包装的? #
1808次浏览 41人参与
# 米连集团26产品管培生项目 #
5845次浏览 214人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7505次浏览 43人参与
# 简历第一个项目做什么 #
31615次浏览 332人参与
# 重来一次,我还会选择这个专业吗 #
433411次浏览 3926人参与
# MiniMax求职进展汇总 #
23922次浏览 308人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187041次浏览 1122人参与
# 牛客AI文生图 #
21417次浏览 238人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152320次浏览 887人参与
# 研究所笔面经互助 #
118886次浏览 577人参与
# 简历中的项目经历要怎么写? #
310142次浏览 4199人参与
# AI时代,哪些岗位最容易被淘汰 #
63520次浏览 808人参与
# 面试紧张时你会有什么表现? #
30493次浏览 188人参与
# 你今年的平均薪资是多少? #
213044次浏览 1039人参与
# 你怎么看待AI面试 #
179946次浏览 1239人参与
# 高学历就一定能找到好工作吗? #
64320次浏览 620人参与
# 你最满意的offer薪资是哪家公司? #
76458次浏览 374人参与
# 我的求职精神状态 #
448014次浏览 3129人参与
# 正在春招的你,也参与了去年秋招吗? #
363316次浏览 2638人参与
# 腾讯音乐求职进展汇总 #
160608次浏览 1111人参与
# 校招笔试 #
470671次浏览 2964人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务