假设我们有一个称为nums的数字列表,我们必须找到一个对(i,j),其中i
因此,如果输入类似于nums = [6、6、2、2、2、2、8],则输出将为11,就像我们选择两个6一样,其得分为6 + 6 + 0-1 = 11 。
为了解决这个问题,我们将按照以下步骤操作:大:= nums [0]
最大:= 0
对于范围为1到nums的i大:=大-1
maxi:=大数+ nums [i]和maxi的最大值
大:=大和数字的最大值[i]
返回最大值
让我们看一下下面的实现以获得更好的理解
示例class Solution:
def solve(self, nums):
large = nums[0]
maxi = 0
for i in range(1, len(nums)):
large -= 1
maxi = max(large + nums[i], maxi)
large = max(large, nums[i])
return maxi
ob = Solution()nums = [6, 6, 2, 2, 2, 8]
print(ob.solve(nums))
输入值[6, 6, 2, 2, 2, 8]
输出结果11