在 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

以上是 在 Python 中查找最大擦除值的程序 的全部内容, 来源链接: utcz.com/z/338691.html

回到顶部