1014. Best Sightseeing Pair
Difficulty: Medium
Topics: Array, Dynamic Programming
You are given an integer array values where values[i] represents the value of the ith sightseeing spot. Two sightseeing spots i and j have a distance j - i between them.
The score of a pair (i < j) of sightseeing spots is values[i] values[j] i - j: the sum of the values of the sightseeing spots, minus the distance between them.
Return the maximum score of a pair of sightseeing spots.
Example 1:
Example 2:
Constraints:
Hint:
Solution:
We can use a single-pass approach with a linear time complexity O(n). The idea is to keep track of the best possible values[i] i as we iterate through the array. This allows us to maximize the score values[i] values[j] i - j for every valid pair (i, j).
Let's implement this solution in PHP: 1014. Best Sightseeing Pair
Explanation:
Initialization:
- maxI is initialized to values[0] because we start evaluating pairs from index 1.
- maxScore is initialized to 0 to track the maximum score.
Iterate Over the Array:
- For each index j starting from 1, calculate the score for the pair (i, j) using the formula: Score = maxI values[j] - j
- Update maxScore with the maximum value obtained.
Update maxI:
- Update maxI to track the maximum possible value of values[i] i for the next iterations.
Return the Maximum Score:
- After iterating through the array, maxScore will contain the maximum score for any pair.
Complexity:
This solution efficiently computes the maximum score while adhering to the constraints and is optimized for large inputs.
Contact Links
If you found this series helpful, please consider giving the repository a star on GitHub or sharing the post on your favorite social networks ?. Your support would mean a lot to me!
If you want more helpful content like this, feel free to follow me:
The above is the detailed content of Best Sightseeing Pair. For more information, please follow other related articles on the PHP Chinese website!