题解 | #用栈来求解汉诺塔问题#

用栈来求解汉诺塔问题

http://www.nowcoder.com/practice/1a2f618b3433487295657b3414f4e7c4

n = int(input())
step = 0
def move(n, fro, to):
    global step
    step += 1
    print("Move " + str(n) + " from " + fro + " to " + to)
    
def hanota(n, a, b, c):
    step = 0
    if n == 1:
        move(n, a, b)
        move(n, b, c)
    else:
        hanota(n - 1, a, b, c)
        move(n, a, b)
        hanota(n - 1, c, b, a)
        move(n, b, c)
        hanota(n - 1, a, b, c)
hanota(n, "left", "mid", "right")
print("It will move " + str(step) + " steps.")
全部评论

相关推荐

10-15 15:00
潍坊学院 golang
跨考小白:这又不是官方
投递拼多多集团-PDD等公司10个岗位
点赞 评论 收藏
分享
11-27 12:36
已编辑
门头沟学院 前端工程师
Apries:这个阶段来说,很厉害很厉害了,不过写的简历确实不是很行,优势删掉吧,其他的还行
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务