关注
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
相关推荐
点赞 评论 收藏
分享
06-02 23:35
门头沟学院 后端 
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 你觉得实习能学到东西吗 #
18957次浏览 464人参与
# 秋招什么时候开投比较合适? #
8309次浏览 169人参与
# 现代汽车前瞻技术研发急速编程挑战赛 #
22661次浏览 188人参与
# 实习,不懂就问 #
30797次浏览 530人参与
# 软开人,秋招你打算投哪些公司呢 #
101164次浏览 951人参与
# 如何准备秋招 #
12567次浏览 225人参与
# 运营人求职交流聚集地 #
141210次浏览 989人参与
# 每个月的工资都是怎么分配的? #
15591次浏览 333人参与
# 你觉得现在还能进互联网吗? #
4915次浏览 102人参与
# 预测一下26届秋招形势 #
26615次浏览 248人参与
# 你们公司几号发工资 #
19158次浏览 129人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
28240次浏览 456人参与
# 晒一晒你收到的礼盒 #
70322次浏览 403人参与
# 打工人的精神状态 #
54382次浏览 993人参与
# 硬件应届生薪资是否普遍偏低? #
72719次浏览 511人参与
# 高考出分的那一天,我__ #
17347次浏览 269人参与
# 大疆今年的机械笔试难吗? #
41564次浏览 456人参与
# 来聊聊你认为的薪资天花板是哪家? #
31007次浏览 175人参与
# 牛客十周岁生日快乐 #
145277次浏览 1613人参与
# 机械实习一天多少钱合适? #
29064次浏览 177人参与
# 大家实习每天都在干啥 #
82964次浏览 506人参与