关注
T4
T2的plus版,思想是一样的。两个长为n的数组,同位置元素可以交换。要求两数组各自的差值数组之和加起来最大,求最小的交换次数。首先注意我们的主要目标是差值数组之和最大,交换次数最小只是其次。同样使用动态规划,sums_n, sums_y分别表示末尾元素保持原位置和交换的情况下最大的差值数组之和,cnts_n, cnts_y对应二者的交换次数。设join_n, join_y分别是当前元素保持原位置和交换的情况下和上一个元素的差值之和,那么根据上一个元素是否交换,有转移方程
sums_n = max(sums_n + join_n, sums_y + join_y)
sums_y = max(sums_n + join_y, sums_y + join_n)
而cnts_n, cnts_y跟着赋值即可,如果括号里二者相等,在优先选择交换次数较小的。
注意sums_n/sums_y逻辑上同时计算,使用临时变量避免前者的计算影响后者。
时间复杂度O(n),空间复杂度O(1)。
查看原帖
点赞 3
相关推荐
sunshine g...:外包岗一半是 5 年经验的,应届生拿什么拼啊
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 什么是优秀的实习经历 #
8272次浏览 208人参与
# 实习简历求拷打 #
11741次浏览 151人参与
# 被上班搭子“传染”了哪些习惯 #
5482次浏览 98人参与
# 秋招被挂春招仍然能投的公司 #
6638次浏览 95人参与
# 工作后,你落下了哪些病根 #
13280次浏览 185人参与
# mt对你说过最有启发的一句话 #
35376次浏览 421人参与
# 作业帮求职进展汇总 #
82867次浏览 547人参与
# 摸鱼被leader发现了怎么办 #
100955次浏览 642人参与
# 考研失败就一定是坏事吗? #
200895次浏览 1369人参与
# 秋招特别不鸣谢 #
15576次浏览 177人参与
# 选实习,你更看重哪方面? #
13906次浏览 216人参与
# 今年秋招你收到了多少封邮件? #
17938次浏览 219人参与
# 机械/制造每日一题 #
80243次浏览 1411人参与
# 第一次面试 #
1036447次浏览 13682人参与
# 携程求职进展汇总 #
839994次浏览 5530人参与
# 毕业论文进行时 #
20872次浏览 131人参与
# 京东美团大战,你怎么看? #
158064次浏览 860人参与
# 工作中遇到的歹人 #
28066次浏览 314人参与
# 你今年的保底offer是哪家 #
155086次浏览 671人参与
# 你投了多少家公司?进展是___ #
188255次浏览 1171人参与
