LeetCode 1014. 最佳观光组合

1014. 最佳观光组合

给你一个正整数数组 values,其中 values[i] 表示第 i 个观光景点的评分,并且两个景点 i和 j 之间的 距离 为 j - i

一对景点(i < j)组成的观光组合的得分为 values[i] + values[j] + i - j ,也就是景点的评分之和 减去 它们两者之间的距离。

返回一对观光景点能取得的最高分。

示例 1:

输入:values = [8,1,5,2,6]
输出:11
解释:i = 0, j = 2, values[i] + values[j] + i - j = 8 + 5 + 0 - 2 = 11

示例 2:

输入:values = [1,2]
输出:2

提示:

  • 2 <= values.length <= 5 * 10^4
  • 1 <= values[i] <= 1000

提示 1

Can you tell the best sightseeing spot in one pass (ie. as you iterate over the input?) What should we store or keep track of as we iterate to do this?

 

解法:遍历j

从前往后遍历 j 来统计答案,
得分公式 values[i]+values[j]+i-j ,我们可以将其拆分成 values[i]+i 和 values[j] − j 两部分,这样对于统计景点 j 答案的时候,由于 values[j] − j 是固定不变的,因此最大化 values[i]+i+values[j]−j 的值其实就等价于求 [0,j−1] 中 values[i]+i 的最大值 preMax,景点 j 的答案即为 preMax+values[j]−j 。而 preMax 的值我们只要从前往后遍历 j 的时候同时维护即可,这样每次遍历到景点 j 的时候,寻找使得得分最大的 i 就能从 O(n) 降至 O(1) 的时间复杂度,总时间复杂度就能从 O(n^2) 降至 O(n)。

类似题:LeetCode 2874. 有序三元组中的最大值 II-CSDN博客

LeetCode 2971. 找到最大周长的多边形-CSDN博客

LeetCode 2748. 美丽下标对的数目-CSDN博客

Java版:

class Solution {
    public int maxScoreSightseeingPair(int[] values) {
        int n = values.length;
        int preMax = values[0] + 0;
        int ans = Integer.MIN_VALUE;
        // 0 <= i < j <= n - 1
        for (int j = 1; j < n; j++) {
            ans = Math.max(ans, preMax + values[j] - j);
            preMax = Math.max(preMax, values[j] + j);
        }
        return ans;
    }
}

Python3版:

class Solution:
    def maxScoreSightseeingPair(self, values: List[int]) -> int:
        preMax = values[0] + 0
        ans = 0
        for j in range(1, len(values)):
            ans = max(ans, preMax + values[j] - j)
            preMax = max(preMax, values[j] + j)
        return ans

复杂度分析

  • 时间复杂度:O(n),其中 n 为数组 values 的大小。我们只需要遍历一遍数组即可。
  • 空间复杂度:O(1)。我们只需要常数空间来存放若干变量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值