python用turtle库绘画树形,python数据结构递归树

大家好,小编来为大家解答以下问题,python用turtle库绘画树形,python数据结构递归树,现在让我们一起来看看吧!

Source code download: 本文相关源码

二叉树形图,显示如下:

基本思路:
首先我们根据前几幅图可以知道迭代次数是2^n - 1,n为迭代层数,因此递归函数大致结构出来了,也就是:

def func():
    if xxx: return   
    else:
        do something
        func()
        func()

xxx是判断结束递归的条件,这里我们很容易知道条件就是level == 0

do something 就是我们要在图上画的动作

那么具体是怎么画呢?

turtle中有俩函数

turtle.right(angle)
turtle.forward(r)

第一个是以当前角度顺时针旋转一个angle角度

第二个是以当前位置为起点,按当前角度画线段,长度为r

记住两个函数都是以当前位置和当前角度的,因此在画线的时候必须调整好起点位置和角度

turtle中有这几个函数

turtle.setheading(0)    #调整角度到0度
turtle.penup()          #抬笔
turtle.goto(x,y)        #将画笔位置移到x,y
turtle.pendown()        #落笔

新的线段起点newx,newy位置可以根据原位置乘以角度的三角函数得到

newx = x+r*math.cos(angle/180 *math.pi)
newy = y-r*math.sin(angle/180 *math.pi)

综上所诉,我们的递归函数的就可以确定了。

代码如下:

import turtle
import math

R = 100

def TreeGraph(x,y,r,angle,level):
    if level == 0:return
    else:
        turtle.setheading(0)
        turtle.penup()
        turtle.goto(x,y)
        turtle.pendown()
        turtle.right(angle)
        turtle.forward(r)

        newx = x+r*math.cos(angle/180 *math.pi)
        newy = y-r*math.sin(angle/180 *math.pi)

        TreeGraph(newx,newy,r*0.5*(2**.5),angle+45,level-1)
        TreeGraph(newx,newy,r*0.5*(2**.5),angle-45,level-1)


if __name__ == "__main__":

    TreeGraph(0,-200,R,-90,9)

    turtle.mainloop()

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值