python递归绘制简单分形树

对于树形结构,首先要明白绘制的过程:

1 绘制右数

2 返回节点

3 绘制左树

4 返回节点

代码:

 

"""
作者:sust_ly
功能:绘制分形树
版本:2.0
日期:2018/3/2
"""
import turtle


def draw_shu(length):
    if length >= 5:
        turtle.forward(length)
        turtle.right(20)
        draw_shu(length - 10)
        turtle.left(40)
        draw_shu(length - 10)
        turtle.right(20)
        turtle.backward(length)


def main():
    turtle.left(90)
    turtle.penup()
    turtle.backward(150)
    turtle.pendown()
    draw_shu(80)
    turtle.done()


if __name__ == "__main__":
    main()

 

 

    turtle.forward(length)
        turtle.right(20)
        draw_shu(length - 10)

当递归执行到上述代码时,将最右侧树型勾勒出来,条件不成立,不执行draw_shuh函数if内容。

 

    turtle.left(40)
        draw_shu(length - 10)

执行到这一句时,同样因条件不成立不会执行这函数里的if条件,直接退出

 

    turtle.right(20)
        turtle.backward(length)

执行这一句,退回到最后一个节点,这时最后一个节点的右边线完成开始执行画右侧最后一个节点的左侧树枝,同上。

当整个递归完成,则:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值