关注
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
相关推荐
昨天 21:34
门头沟学院 测试开发 点赞 评论 收藏
分享
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 你最近因为什么迷茫? #
9925次浏览 175人参与
# 实习怎么做才有更好的产出 #
2043次浏览 72人参与
# 上班以后,你还有哪些坚持的爱好? #
1389次浏览 45人参与
# AI coding的好用工具分享 #
2747次浏览 94人参与
# 领导做过最不靠谱的事 #
4581次浏览 82人参与
# 实习生工资多少才算正常? #
3242次浏览 77人参与
# 实习心态崩了 #
100479次浏览 513人参与
# 找工作以来,你最看不惯__ #
2559次浏览 70人参与
# 你都在哪些场所面过试? #
4249次浏览 67人参与
# 你给AI提过哪些离谱的需求? #
1504次浏览 47人参与
# 哪些公司开春招了? #
1804次浏览 29人参与
# 秋招有哪些公司要求提前实习 #
102695次浏览 545人参与
# 非技术岗投递进展 #
166645次浏览 1317人参与
# 新年的第一句祝福 #
53597次浏览 389人参与
# 华为保温 #
169633次浏览 642人参与
# 实习转正进行时 #
138656次浏览 897人参与
# 工作压力大怎么缓解 #
132423次浏览 1139人参与
# 24届的你们现状如何了? #
107284次浏览 515人参与
# 你觉得第一学历对求职有影响吗? #
222257次浏览 1229人参与
# 上班苦还是上学苦呢? #
320199次浏览 2052人参与