在 Python 中查找子数组上的最小增量数以形成目标数组的程序
假设我们有一个名为target的数组,其值为正。现在考虑一个大小相同且全为零的数组初始值。如果我们执行此操作,我们必须找到从初始值生成目标数组所需的最小操作数:(从初始值中选择任何子数组并将每个值加一。)
因此,如果输入类似于target=[2,3,4,3,2],那么输出将是4,因为最初数组是[0,0,0,0,0]首先通过选择子数组从索引0到4并将其增加1,因此数组将是[1,1,1,1,1],然后再次从索引0到4中选择使其成为[2,2,2,2,2],然后从中选择元素索引1到3并增加,因此数组将是[2,3,3,3,2],最后选择索引2并制作与目标相同的数组[2,3,4,3,2]。
示例
让我们看下面的实现来更好地理解
def solve(target):
prev_num = 0
steps = 0
for val in target:
steps += val-prev_num if val > prev_num else 0
prev_num = val
return steps
target = [2,3,4,3,2]
print(solve(target))输入
[2,3,4,3,2]输出结果
4
热门推荐
10 香港老妈结婚祝福语简短
11 毕业立体贺卡祝福语简短
12 简短新年年会祝福语
13 评论小品祝福语大全简短
14 恭喜师兄结婚祝福语简短
15 员工集体辞职祝福语简短
16 高中新生祝福语 简短
17 装修祝福语男生搞笑简短
18 生日开业蛋糕祝福语简短