用于查找在 Python 中最大化给定数组表达式的值的程序
假设我们有两个数组 nums 和 values,都包含整数,并且 nums 的值严格递增,并且它们的长度也相同。我们必须为一对索引 i, j 找到 v 的值,使得: i ≤ j 最大化 v = values[i] + values[j] + nums[j] - nums[i]。
所以,如果输入像 nums = [1, 2, 7] values = [-4, 6, 5],那么输出将是 16,如果我们选择 i = 1 和 j = 2 我们得到 6 + 5 + 7 - 2 = 16。
示例
让我们看下面的实现来更好地理解
from math import infdef solve(nums, values):
ans1 = -inf
ans2 = -inf
for i in range(len(nums)):
ans1 = max(ans1, (values[i] - nums[i]))
ans2 = max(ans2, (values[i] + nums[i]))
return ans1 + ans2
nums = [1, 2, 7]
values = [-4, 6, 5]
print(solve(nums, values))
输入
[1, 2, 7], [-4, 6, 5]输出结果
16
以上是 用于查找在 Python 中最大化给定数组表达式的值的程序 的全部内容, 来源链接: utcz.com/z/343697.html