1014. 最佳观光组合
大约 1 分钟
---
1014. 最佳观光组合
- 标签:数组、动态规划
- 难度:中等
题目链接
题目大意
给你一个正整数数组 values,其中 values[i] 表示第 i 个观光景点的评分,并且两个景点 i 和 j 之间的距离 为 j - i。一对景点(i < j)组成的观光组合的得分为 values[i] + values[j] + i - j,也就是景点的评分之和减去它们两者之间的距离。
要求:返回一对观光景点能取得的最高分。
解题思路
求解的是 ans = max(values[i] + values[j] + i - j)。对于当前第 j 个位置上的元素来说,values[j] - j 的值是固定的,求解 ans 就是在求解 values[i] + i 的最大值。我们使用一个变量 max_score 来存储当前第 j 个位置元素之前 values[i] + i 的最大值。然后遍历数组,求出每一个元素位置之前 values[i] + i 的最大值,并找出其中最大的 ans。
代码
class Solution:
def maxScoreSightseeingPair(self, values: List[int]) -> int:
ans = 0
max_score = values[0]
for i in range(1, len(values)):
ans = max(ans, max_score + values[i] - i)
max_score = max(max_score, values[i] + i)
return ans