程序查找在Python中达到目标所需的给定操作数
假设我们有两个值start和end,我们必须使用这些操作找到将start转换为end所需的最小操作数-
减1
乘以2
因此,如果输入类似于start=2,end=7,则输出将为3,因为我们可以将2乘以得到4,然后将2乘以得到8,然后减去1来得到7。
为了解决这个问题,我们将遵循以下步骤-
回答:=0
无限执行以下操作
结束:=结束/2的商
回答:=回答+1
结束:=结束+1,ANS:=ANS+1
返回ans+开始-结束
如果结束<=开始,则
否则当结尾是奇数时
除此以外,
让我们看下面的实现以更好地理解-
示例
class Solution:
def solve(self, start, end):
ans = 0
while True:
if end <= start:
return ans + start - end
elif end % 2:
end += 1
ans += 1
else:
end //= 2
ans += 1
ob1 = Solution()start = 2
end = 7
print(ob1.solve(start, end))输入项
2, 7
输出结果
3
热门推荐
10 香港老妈结婚祝福语简短
11 毕业立体贺卡祝福语简短
12 简短新年年会祝福语
13 评论小品祝福语大全简短
14 恭喜师兄结婚祝福语简短
15 员工集体辞职祝福语简短
16 高中新生祝福语 简短
17 装修祝福语男生搞笑简短
18 生日开业蛋糕祝福语简短