用PYTHON画斐波那契数列银杏树(代码可复制)

您所在的位置:网站首页 斐波那契数列图形怎么画 用PYTHON画斐波那契数列银杏树(代码可复制)

用PYTHON画斐波那契数列银杏树(代码可复制)

2024-07-14 04:50| 来源: 网络整理| 查看: 265

今天我们来画斐波那契数列银杏树,先看一下结果:

首先,我们先引入turtle,random,math三个包。

import turtle import random import math

斐波那契数列大家应该知道的,下面这段代码就是做斐波那契数列的带吗

def Fibonacci_Recursion_tool(n): if n 6: #此时画飘落的叶子,x范围太大会导致树太秃 turtle.forward(length) # 画树枝 yu[level] = yu[level] - 1 c = random.randint(2, 10) for i in range(1, c): leaf(turtle.xcor(), turtle.ycor(), node) # 添加0.3倍的飘落叶子 if random.random() > 0.3: turtle.penup() # 飘落 t1 = turtle.heading() an1 = -40 + random.random() * 40 turtle.setheading(an1) dis = int(800 * random.random() * 0.5 + 400 * random.random() * 0.3 + 200 * random.random() * 0.2) turtle.forward(dis) turtle.setheading(t1) turtle.right(90) # 画叶子 leaf(turtle.xcor(), turtle.ycor(), node) turtle.left(90) # 返回 t2 = turtle.heading() turtle.setheading(an1) turtle.backward(dis) turtle.setheading(t2) elif level==top and x < 7 : #此时画枝叶,x范围太大会导致飘落的叶子太少 turtle.penup() turtle.forward(length) elif level>3 and (x>6) :#三级树枝以上,有40%的概率执行以下策略 turtle.pendown() turtle.forward(length) c = random.randint(4, 6) for i in range(3, c): leaf(turtle.xcor(), turtle.ycor(),node) leaf(turtle.xcor(), turtle.ycor(),node) button=1# jump""" else: turtle.forward(length) # 画树枝 yu[level] = yu[level] -1 if node > 0 and button == 0: # 计算右侧分支偏转角度,在固定角度偏转增加一个随机的偏移量 right = random.random() * 5 + 17 # 计算左侧分支偏转角度,在固定角度偏转增加一个随机的偏移量 left = random.random() * 20 + 19 # 计算下一级分支的长度 child_length = length * (random.random() * 0.25 + 0.7) # 右转一定角度,画右分支 r=random.randint(0, 1) if r==1: turtle.right(right) level = level + 1 #print("level", level) else: turtle.left(right) level = level + 1 #print("level", level) draw(node - 1, child_length,level,yu,button) yu[level] = yu[level] +1 if yu[level] > 1: # 左转一定角度,画左分支 if r==1: turtle.left(right + left) draw(node - 1, child_length, level, yu,button) # 将偏转的角度,转回 turtle.right(left) yu[level] = yu[level] - 1 else: turtle.right(right + left) draw(node - 1, child_length, level, yu,button) # 将偏转的角度,转回 turtle.left(left) yu[level] = yu[level] - 1 else: if r==1: turtle.left(right + left) turtle.right(left) else: turtle.right(right + left) turtle.left(left) turtle.penup() #退回到上一级节点顶部位置 turtle.backward(length) """ 5.主函数部分 主函数中直接调用上述函数就行,top控制树的高度,turtle.speed控制画的速度,最后的turtle.write()用来书写最下方的签名。 ```clike """ if __name__ == '__main__': turtle.setup(width=1.0, height=1.0) #设置全屏显示 turtle.hideturtle() # 隐藏turtle turtle.speed(0) # 设置画笔移动的速度,0-10 值越小速度越快 # turtle.tracer(0,0) #设置动画的开关和延迟,均为0 turtle.penup() # 抬起画笔 turtle.left(90) # 默认方向为朝x轴的正方向,左转90度则朝上 turtle.backward(300) # 设置turtle的位置,朝下移动300 top = 9 #树高 yu = Fibonacci_Recursion(top) #生成斐波那契数列 yu.remove(yu[0]) #print(yu) 打印斐波那契数列 button = 0 draw(top, 120, 0, yu, button) # 调用函数开始绘制 turtle.write(" Luke Skywalker'", font=("微软雅黑", 14, "normal")) #生成签名 turtle.done()

好了,今天的斐波那契数列银杏树就到这了,想要源码的链接在下面↓

链接 https://pan.baidu.com/s/1LlExMojcSDjb4dZ_HZU6tg?pwd=3mgz: 提取码: 3mgz 



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3