用递归画谢尔宾斯基三角形

之前都是用循环画的,今天了解到用递归去画,一时间有点懵

不太理解递归的用法

递归要有终止条件

先要定义函数(参数)

终止条件

调用函数

import turtle as t

def draw_sierpinski(triangle,degree):#triangle三角形的三个顶点坐标,degree深度、度

a,b,c=triangle

draw_triangle(a,b,c)#绘制三角形外轮廓

if degree==0:#终止条件

return

else:

d=get_midpoint(a,b)

e=get_midpoint(b,c)

f=get_midpoint(c,a)#取中点坐标

draw_sierpinski([a,d,f],degree-1)

draw_sierpinski([d,b,e],degree-1)

draw_sierpinski([f,e,c],degree-1)#递归调用

def draw_triangle(a,b,c):#自定义绘制三角形函数

ax,ay=a

bx,by=b

cx,cy=c

t.penup()

t.goto(ax,ay)

t.pendown()

t.goto(bx,by)

t.goto(cx,cy)

t.goto(ax,ay)

t.penup()

def get_midpoint(m,n):

mx,my=m

nx,ny=n

return(mx+nx)/2,(my+ny)/2

triangle=[[0,200],[-200,-100],[200,-100]]

draw_sierpinski(triangle,3)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
使用Python绘制谢尔宾斯基三角形可以通过递归的方式实现。具体步骤如下: 1. 导入turtle库,创建一个布和一个海龟对象。 2. 定义一个函数sierpinski(points, degree, myTurtle),其中points是三角形的三个顶点坐标,degree是递归的深度,myTurtle是海龟对象。 3. 在函数中,如果degree等于0,则绘制三角形;否则,递归调用sierpinski函数,将degree减1,并将三角形分成三个小三角形,分别递归绘制。 4. 在主程序中,定义三角形的三个顶点坐标,调用sierpinski函数开始绘制。 下面是代码示例: ``` import turtle def drawTriangle(points, color, myTurtle): myTurtle.fillcolor(color) myTurtle.up() myTurtle.goto(points[0][0], points[0][1]) myTurtle.down() myTurtle.begin_fill() myTurtle.goto(points[1][0], points[1][1]) myTurtle.goto(points[2][0], points[2][1]) myTurtle.goto(points[0][0], points[0][1]) myTurtle.end_fill() def getMid(p1, p2): return ((p1[0]+p2[0])/2, (p1[1]+p2[1])/2) def sierpinski(points, degree, myTurtle): colormap = ['blue', 'red', 'green', 'white', 'yellow', 'violet', 'orange'] drawTriangle(points, colormap[degree], myTurtle) if degree > 0: sierpinski([points[0], getMid(points[0], points[1]), getMid(points[0], points[2])], degree-1, myTurtle) sierpinski([points[1], getMid(points[0], points[1]), getMid(points[1], points[2])], degree-1, myTurtle) sierpinski([points[2], getMid(points[2], points[1]), getMid(points[0], points[2])], degree-1, myTurtle) def main(): myTurtle = turtle.Turtle() myWin = turtle.Screen() myPoints = [[-100,-50],[0,100],[100,-50]] sierpinski(myPoints, 3, myTurtle) myWin.exitonclick() main() ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值