在 Python 中查找最大擦除值的程序
假设我们有一个名为nums的数组(只有正值),并且我们想要删除一个包含唯一元素的子数组。我们将得到分数,即子数组元素的总和。我们必须找到通过擦除一个子数组可以获得的最大分数。
因此,如果输入类似于nums=[6,3,2,3,6,3,2,3,6],那么输出将是11,因为这里的最佳子数组是[6,3,2]或[2,3,6],所以总和是11。
示例
让我们看看以下实现以获得更好的理解-
def solve(nums):
seen = dict()
ans = sum = 0
l = 0
for r, x in enumerate(nums):
if x in seen:
index = seen[x]
while l <= index:
del seen[nums[l]]
sum -= nums[l]
l += 1
seen[x] = r
sum += x
ans = max(ans, sum)
return ans
nums = [6,3,2,3,6,3,2,3,6]
print(solve(nums))输入
[6,3,2,3,6,3,2,3,6]输出结果
11
热门推荐
10 关于早晨的祝福语简短
11 婚礼祝福语简短情话文案
12 祝福语简短七夕
13 升职祝福语朋友简短精辟
14 七一祝福语明信片文案简短
15 恋爱祝福语大全简短搞笑
16 日常祝福语简短语客户
17 小孩想说的祝福语简短
18 送礼祝福语男性生日简短