手机版
你好,游客 登录 注册
背景:
阅读新闻

使用Python turtle库绘制科赫雪花曲线

[日期:2019-03-28] 来源:Linux社区  作者:N_jessica [字体: ]

使用Python turtle库绘制科赫雪花曲线代码及解析。

完整代码如下:

from turtle import *
# 最重要的便是递归函数:要理解科赫曲线的原理:取一段直线的1/3长度,
# 以该长度的4条小直线拼成,其中中间两条小直线凸起(60度)
# 以此类推,每条小直线再接着细分
def koch(size,n):
    if n==0:
        fd(size)
    else:
        for angel in [0,60,-120,60]:
            left(angel)
            koch(size/3,n-1)
# 上面函数:在最外层的循环执行转角度后再调用下一阶及相应的直线长度(0、60、-120、60)
# 这些角度都是并列关系,每一层又包含着调用递归也是这四个角度
# 其实最里面的递归调用效果就是把每个小直线分成四段,中间突起
# 下面函数后面的代码是形成一个大三角,把每个边绘制成科赫曲线,三角形三个边通过角度进行转换连接
def main():
    setup(600,600)
    penup()
    goto(-200,100)
    pendown()
    pensize(2)
    level=3
    koch(400,level)
    right(120)
    koch(400,level)
    right(120)
    koch(400,level)
    hideturtle()

main()

效果图如下:

使用Python turtle库绘制科赫雪花曲线

更多Python相关信息见Python 专题页面 https://www.linuxidc.com/topicnews.aspx?tid=17

Linux公社的RSS地址https://www.linuxidc.com/rssFeed.aspx

本文永久更新链接地址https://www.linuxidc.com/Linux/2019-03/157772.htm

linux