从 Python 中所有可能的有效路径中查找最高分的程序
假设我们有两个数组 nums1 和 nums2。有效路径定义如下 -
选择 nums1 或 nums2 进行遍历(从 index-0 开始)。
从左到右遍历数组。
现在,如果我们正在遍历 nums1 和 nums2 中存在的任何值,我们可以将路径更改为另一个数组。这里的分数是有效路径中唯一值的总和。我们必须找到所有可能的有效路径的最高分。如果答案太大,则返回模 10^9+7 的结果。
因此,如果输入类似于 nums1 = [3,5,6,9,11] nums2 = [5,7,9,10],那么输出将为 35,因为 -
从 nums1 开始的有效路径为:[3,5,6,9,11], [3,5,6,9,10], [3,5,7,9,10], [3,5,7, 9,11]
从 nums2 开始的有效路径为:[5,7,9,10], [5,6,9,11], [5,6,9,10], [5,7,9,11]
所以最大值是 [3,5,7,9,11]。
示例
让我们看看以下实现以更好地理解
def solve(nums1, nums2):M, N = len(nums1), len(nums2)
sum1, sum2 = 0, 0
i, j = 0, 0
res = 0
while i < M and j < N:
if nums1[i] < nums2[j]:
sum1 += nums1[i]
i += 1
elif nums1[i] > nums2[j]:
sum2 += nums2[j]
j += 1
else:
res += max(sum1, sum2) + nums1[i]
i += 1
j += 1
sum1 = 0
sum2 = 0
while i < M:
sum1 += nums1[i]
i += 1
while j < N:
sum2 += nums2[j]
j += 1
return (res + max(sum1, sum2)) % 1000000007
nums1 = [3,5,6,9,11]
nums2 = [5,7,9,10]
print(solve(nums1, nums2))
输入
[3,5,6,9,11], [5,7,9,10]输出结果
35
以上是 从 Python 中所有可能的有效路径中查找最高分的程序 的全部内容, 来源链接: utcz.com/z/363235.html