python 趣味习题_递归函数(谢尔宾斯基三角形 画法)

这里写目录标题

本专栏旨在记录本人解决问题的思考方法,及实现过程。有更好方法或对程序执行有疑问的伙伴,可在评论区留言,共同讨论。

这里写目录标题

一级目录

二级目录

三级目录

题目要求

  • 定义: 谢尔宾斯基三角形最早由波兰数学家谢尔宾斯基在1915年提出。它的构造方法是:以一个正三角形为初始图形,每次将正三角形分割成4个边长为原来一半的小三角形,并去掉其中间的小三角形,重复这一过程,直到不能再分割为止。
  • 要求: 用最简单的代码,绘制出谢尔宾斯基三角形。

最终结果


解决流程

绘制中发现,如果完全按照定义,通过每次截取的方式(每次在三角形中截取一个三角形),则需用到大量的计算,如何确定每一次画笔的位置也是一个难题。

本人在绘制中,通过按边绘制,如果非最后一层,则取半绘制三角形,这样减少了计算量,并且只用 6 段代码就实现了谢尔斯基三角形的绘制。

程序实现

python 复制代码
import turtle

turtle.setup(500,500)  # 窗口大小
turtle.screensize(400, 400)  # 画布大小
#turtle.tracer(False)  # 省略绘制过程
t = turtle.Turtle()
t.penup()
t.goto(0, 200)
t.pendown()
t.color('blue', 'yellow')
t.left(60)
# 定义基本参数
bc = 400  # 边长


# 绘制函数
def huasj(n, jbc):
    if n != 0:
        for _ in range(3):
            huasj(n - 1, jbc / 2)
            t.right(120)
            t.forward(jbc)


#绘制连长为 400 的 5 层三角形
huasj(5, bc)

t.hideturtle()
turtle.update()  # 更新画布
turtle.done()

** 递归绘制函数:**

python 复制代码
def huasj(n, jbc):
    if n != 0:
        for _ in range(3):
            huasj(n - 1, jbc / 2)
            t.right(120)
            t.forward(jbc)

** 递归函数说明:** 1.递归结束条件,层数为0时不执行;2.递归执行过程,如果 n > 1 ,则执行 n - 1。

运行示例

下图为连长为400, 层数为7的 谢尔宾斯基三角形 示例:

小结

该方法,仍然受到递归限制,层数不能增大,同时在 liunx 中运行画三角形时,不能进行色彩填充。

相关推荐
想躺平的咸鱼干5 分钟前
Volatile解决指令重排和单例模式
java·开发语言·单例模式·线程·并发编程
Owen_Q23 分钟前
Denso Create Programming Contest 2025(AtCoder Beginner Contest 413)
开发语言·算法·职场和发展
·云扬·40 分钟前
【Java源码阅读系列37】深度解读Java BufferedReader 源码
java·开发语言
liulilittle1 小时前
C++ i386/AMD64平台汇编指令对齐长度获取实现
c语言·开发语言·汇编·c++
巴里巴气1 小时前
selenium基础知识 和 模拟登录selenium版本
爬虫·python·selenium·爬虫模拟登录
19892 小时前
【零基础学AI】第26讲:循环神经网络(RNN)与LSTM - 文本生成
人工智能·python·rnn·神经网络·机器学习·tensorflow·lstm
JavaEdge在掘金2 小时前
Redis 数据倾斜?别慌!从成因到解决方案,一文帮你搞定
python
ansurfen2 小时前
我的第一个AI项目:从零搭建RAG知识库的踩坑之旅
python·llm
Thomas_YXQ2 小时前
Unity URP法线贴图实现教程
开发语言·unity·性能优化·游戏引擎·unity3d·贴图·单一职责原则
前端付豪2 小时前
20、用 Python + API 打造终端天气预报工具(支持城市查询、天气图标、美化输出🧊
后端·python