Python 程序查找最大擦除值
假设我们有一个名为 nums 的数组(仅包含正值),我们想要擦除一个包含唯一元素的子数组。我们将获得一个分数,即子数组元素的总和。我们必须找到通过精确擦除一个子数组可以获得的最大分数。
因此,如果输入类似于 nums = [6,3,2,3,6,3,2,3,6],则输出将为 11,因为这里的最佳子数组是 [6,3,2] 或 [2,3,6],所以总和为 11。
为了解决这个问题,我们将遵循以下步骤 -
- seen := 一个新的映射
- ans := sum := 0
- l := 0
- 对于每个索引 r 和值 x nums,执行
- 如果 x 出现在 seen 中,则
- index := seen[x]
- 当 l <= index 时,执行
- 删除 seen[nums[l]]
- sum := sum - nums[l]
- l := l + 1
- seen[x] := r
- sum := sum + x
- ans := ans 和 sum 的最大值
- 如果 x 出现在 seen 中,则
- 返回 ans
示例
让我们看看以下实现以获得更好的理解 -
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
广告