两个python小练习 (汉诺塔 杨辉三角)

汉诺塔 原理:利用递归

1、将前n-1个盘子从A移到B上

2、将最后一个盘子从A移到C上

3、将B的n-1个移到C上

其次数为:1,3,7……即2n+1

python代码:

def move(n,a,b,c):
    if n==1:
        print (a,'-->',c)
    else:
        move(n-1,a,c,b)
        print(a,'-->',c)
        move(n-1,b,a,c) 

move(3,'a','b','c')

输出:

a --> c
a --> b
c --> b
a --> c
b --> a
b --> c
a --> c


杨辉三角


利用生成器

 def triangles():
    L1=[1]
    while 1:
        yield L1
        L1=[L1[i-1]+L1[i] for i in range(1,len(L1))]
        L1.insert(0,1)
        L1.append(1)

n = 0
for t in triangles():
    print(t)
    n = n + 1
    if n == 10:
        break
   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值