首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Sierpinski三角Pygame递归函数

Sierpinski三角是一种由递归函数生成的图形,它是一个由小三角形组成的大三角形。每个小三角形都是通过将大三角形划分为四个相似的小三角形而生成的。Sierpinski三角的生成过程可以通过递归函数来实现。

在Pygame中,可以使用递归函数来绘制Sierpinski三角。首先,需要定义一个递归函数,该函数接受三个顶点坐标和递归深度作为参数。在每次递归调用中,将大三角形划分为四个小三角形,并对每个小三角形进行递归调用,直到达到指定的递归深度。

以下是一个示例的递归函数实现Sierpinski三角的代码:

代码语言:txt
复制
import pygame

def draw_sierpinski_triangle(screen, color, depth, x1, y1, x2, y2, x3, y3):
    if depth == 0:
        pygame.draw.polygon(screen, color, [(x1, y1), (x2, y2), (x3, y3)], 0)
    else:
        # 计算三个顶点的中点
        mid1_x = (x1 + x2) // 2
        mid1_y = (y1 + y2) // 2
        mid2_x = (x2 + x3) // 2
        mid2_y = (y2 + y3) // 2
        mid3_x = (x3 + x1) // 2
        mid3_y = (y3 + y1) // 2

        # 递归绘制三个小三角形
        draw_sierpinski_triangle(screen, color, depth-1, x1, y1, mid1_x, mid1_y, mid3_x, mid3_y)
        draw_sierpinski_triangle(screen, color, depth-1, mid1_x, mid1_y, x2, y2, mid2_x, mid2_y)
        draw_sierpinski_triangle(screen, color, depth-1, mid3_x, mid3_y, mid2_x, mid2_y, x3, y3)

def main():
    pygame.init()
    width, height = 800, 600
    screen = pygame.display.set_mode((width, height))
    pygame.display.set_caption("Sierpinski Triangle")
    clock = pygame.time.Clock()
    running = True

    while running:
        for event in pygame.event.get():
            if event.type == pygame.QUIT:
                running = False

        screen.fill((255, 255, 255))
        draw_sierpinski_triangle(screen, (0, 0, 0), 5, 400, 100, 100, 500, 700, 500)
        pygame.display.flip()
        clock.tick(60)

    pygame.quit()

if __name__ == "__main__":
    main()

这段代码使用Pygame库来创建一个窗口,并在窗口中绘制Sierpinski三角。在main()函数中,我们初始化Pygame,设置窗口的大小和标题,并创建一个游戏循环来处理事件和绘制图形。在游戏循环中,我们使用draw_sierpinski_triangle()函数来绘制Sierpinski三角,传入屏幕对象、颜色、递归深度和三个顶点的坐标。

Sierpinski三角的递归生成过程可以通过不断划分三角形来创建复杂的图案。它在计算机图形学和图像处理中有广泛的应用,例如纹理生成、图像压缩和图像分形等领域。

腾讯云提供了丰富的云计算产品和服务,其中包括云服务器、云数据库、云存储、人工智能等。您可以访问腾讯云官方网站(https://cloud.tencent.com/)了解更多关于腾讯云的产品和服务信息。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

NumPy 初学者指南中文第三版:11~14

下表总结了通过审查的函数函数 描述 pygame.init() 此函数执行初始化,您必须在调用其他 Pygame 函数之前调用它。...,我们将使用 OpenGL 绘制一个 Sierpinski 地毯,也称为 Sierpinski 三角形或 Sierpinski 筛子。...这是由数学家 Waclaw Sierpinski 创建的三角形形状的分形图案。 三角形是通过递归且原则上是无限的过程获得的。 首先,首先初始化一些与 OpenGL 相关的原语。...其次,我们定义一个三角形的顶点(我称它们为点)。 然后,我们定义随机索引,该随机索引将用于选择三个三角形顶点之一。 我们在中间的某个地方随机选择一个点,实际上并不重要。...三角形如下所示: 带有所有导入的完整 Sierpinski 垫圈演示代码如下: import pygame from pygame.locals import * import numpy as np

3.1K10

【我和Python算法的初相遇】——体验递归的可视化篇

递归的起源 递归是一种算法,它利用函数的自身调用来解决问题。递归的历史可以追溯到古代的数学家和逻辑学家,如希腊哲学家亚里士多德和印度数学家阿耶尔巴塔。...这导致了一些数学家开始研究递归函数,因为递归函数是一种强大的工具,可以用来刻画数学中的可计算性概念。在20世纪40年代,递归理论被广泛研究,它为计算机科学的发展奠定了基础。...turtle.Screen() t.left(90) t.up() t.backward(200) t.down() t.color("black") tree(110,t) my_win.exitonclick() 利用递归画一个谢尔平斯基三角形...#绘制谢尔平斯基三角形的辅助函数 import turtle def draw_triangle(points , color, my_turtle ): my_turtle.fillcolor...—— 我们通过递归可以将复杂问题简单化,并且我们还学习了如何通过递归进行进制转换,以及如何通过递归去画出我们想要的图形---螺旋图,分形树,谢尔基三角形。

23810
  • 附加实验1 Sierpinski三角

    3.实验原理:     Sierpinski三角形是一种分形图形,它是递归地构造的。...最常见的构造方法如下图所示:把一个三角形分成四等份,挖掉中间那一份,然后继续对另外三个三角形进行这样的操作,并且无限地递归下去。...这也就是说,Sierpinski三角形其实是一条曲线。 ? 图1 大概在下图上标注了一下一个三角形迭代过程: ?...图2 生成Sierpinski 三角形算法描述,如图1所示: (1)从一个三角形开始; (2)连接三边的中点并去掉中间的三角形; (3)重复上述过程; 4.示范代码: #include <GL/glut.h...GLUT_RGB);     glutInitWindowSize(500, 500);     glutInitWindowPosition(50,50);     glutCreateWindow("2D Sierpinski

    57520

    Python面试算法:绘制谢尔宾斯基三角

    所以我们只需要绘制除了6级三角形外的其他三角形中三个角的小三角形即可。由于每一个三角形都会重复同一个动作(绘制三个更小的三角形),这明显是递归动作。...递归的基本流程如下: step1:绘制大三角形 step2:绘制大三角形中三个顶点的小三角形 step3:重复step1,将大三角形看做step2绘制的小三角形,继续绘制这个小三角形中三个顶点的小三角形...,直到级别为6为止(最小的三角形),这是递归终止条件。...函数用于获取三角形两个顶点的中间点,draw_triangle函数用于通过海龟对象绘图。...这两个函数以及调用代码如下: import turtle # 绘制一个三角形 def draw_triangle(points, color,myTurtle): myTurtle.fillcolor

    1.3K20

    Python编程 深入浅出递归

    递归调用的实现: 当一个函数被调用的时候,系统会把调用时的现场数据压入到系统调用栈。...每次调用,压入栈的现场数据称为栈帧,当函数返回时,要从调用栈的栈顶取得返回地址,恢复现场,弹出栈帧,按地址返回。...谢尔宾斯基三角形(英语:Sierpinski triangle)也是一种分形,由波兰数学家谢尔宾斯基在 1915 年提出,它是自相似集的例子。...同时,这 3 个 degree=n-1 的三角形边长均为degree=n的三角形的一半(规模减小)。当degree=0,则就是一个等边三角形,这是递归基本结束条件。...递归不总是最合适的算法,有时候递归算法会引发巨量的重复计算,"记忆化/函数值缓存"可以通过附加存储空间记录中间计算结果来有效减少重复计算。

    40810

    递归函数

    如果一个函数在内部调用自身,这个函数就叫做递归函数 递归函数的简单定义如下: def recursion(): return recursion() 这只是一个简单的定义,什么也做不了。...,当然,我们需要能实际做事情的函数,有用的递归函数应该满足如下条件: (1)当函数直接返回值时有基本实例(最小可能性问题) (2)递归实例,包括一个或多个问题最小部分的递归调用 使用递归的关键在于将问题分解为小部分...,递归函数的有点是定义简单,逻辑清晰。...理论上,所有递归函数都可以写成循环的方式,不过循环的逻辑不如递归清晰。 使用递归函数需要注意仿制栈溢出,在计算机中,函数调用通过栈(stack)这种数据结构实现的。...由于上面的fact(n)函数return n*(n-1)引入了乘法表达式,因此不是尾递归,要改成尾递归方式需要多一点代码,主要是把每一步乘积传入递归函数(通过把乘积结果传入函数参数的方式),看如下函数定义方式

    69210

    递归函数

    递归 递归就是一个函数在它的函数体内调用它自身。执行递归函数将反复调用其自身,每调用一次就进入新的一层。递归函数必须有结束条件。...注: 递归的时候,每次调用一个函数,计算机都会为这个函数分配新的空间,这就是说,当被调函数返回的时候,调用函数中的变量依然会保持原先的值,否则也不可能实现反向输出。...特点: 递归函数特点 每一级函数调用时都有自己的变量,但是函数代码并不会得到复制,如计算5的阶乘时每递推一次变量都不同; 每次调用都会有一次返回,如计算5的阶乘时每递推一次都返回进行下一次; 递归函数中...,位于递归调用前的语句和各级被调用函数具有相同的执行顺序; 递归函数中,位于递归调用后的语句的执行顺序和各个被调用函数的顺序相反; 递归函数中必须有终止语句。...综上: 函数调用的时候,每次调用时要做地址保存,参数传递等,这是通过一个递归工作栈实现的。具体是每次调用函数本身要保存的内容包括:局部变量、形参、调用函数地址、返回值。

    69330

    函数递归

    如果一个函数在内部调用自身本身,则该函数就是递归函数 递归优缺点   优点:使用递归函数的优点是逻辑简单清晰      理论上,所有的递归函数都可以写成循环的方式,但循环的逻辑不如递归清晰...  缺点:过深的调用会导致栈溢出 栈溢出   使用递归函数需要注意防止栈溢出   在计算机中,函数调用是通过栈(stack)这种数据结构实现的   每当进入一个函数调用,栈就会加一层栈帧...,每当函数返回,栈就会减一层栈帧   由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出 尾递归   解决递归调用栈溢出的方法是通过尾递归优化   事实上尾递归和循环的效果是一样的...,所以,把循环看成是一种特殊的尾递归函数也是可以的   尾递归是指,在函数返回的时候,调用自身本身,并且return语句不能包含表达式   例如,def fun(n) : retrun n*fun(n-...尾递归事实上和循环是等价的,没有循环语句的编程语言只能通过尾递归实现循环 Python标准的解释器没有针对尾递归做优化,任何递归函数都存在栈溢出的问题 使用示例: def fact(n):   return

    94710

    python递归函数讲解_Python递归函数实例讲解

    Python递归函数实例讲解 Python递归函数实例 1、打开Python开发工具IDLE,新建‘递归.py’文件,并写代码如下: def digui(n): if n == 0 : print (”...5、再更改递归函数递归函数带返回值,代码如下: def digui(n): if n == 0 : return 0 return n+digui(n-1) if __name__ == ‘__main...一.递归 是指函数/过程/子程序在运行过程序中直接或间接调用自身而产生的重入现象.在计算机编程里,递归指的是一个过程:函数不断引用自身,直到引用的对象已知.使用递归解决问题,思路清晰,代码少.但是在主流高级语言中...递归函数:在一个函数里在调用这个函数本身....递归的最大深度:998 正如你们刚刚看到的,递归函数如果不受到外力的阻止会一直执行下去.但是我们之前已经说过关于函数调用的问题,每一次函数调用都会产生一个属于它自己的名称空间,如果一直调用下去,就会造成名称空间占用太多内存的问题

    3.4K20

    递归函数

    怯懦的朋友在叛离之后,会成为最凶残的仇敌——埃·斯宾塞 中文文档 Kotlin 支持一种称为尾递归函数式编程风格。 这允许一些通常用循环写的算法改用递归函数来写,而无堆栈溢出的风险。...当一个函数用 tailrec 修饰符标记并满足所需的形式时,编译器会优化该递归,留下一个快速而高效的基于循环的版本: val eps = 1E-10 // "good enough", could be...x) if (Math.abs(x - y) < eps) return x x = Math.cos(x) } } 要符合 tailrec 修饰符的条件的话,函数必须将其自身调用作为它执行的最后一个操作...在递归调用后有更多代码时,不能使用尾递归,并且不能用在 try/catch/finally 块中。目前在 Kotlin for JVM 与 Kotlin/Native 中支持尾递归

    72620

    优化函数递归

    递归是指函数/过程/子程序在运行过程序中直接或间接调用自身而产生的重入现象。在计算机编程里,递归指的是一个过程:函数不断引用自身,直到引用的对象已知。使用递归解决问题,思路清晰,代码少。...下面我们以 n = 5 代入上面的函数,手动执行一下这个函数。 我要计算 fib(5),那么我就需要计算 fib(4)和 fib(3)。...因为这个次数限制是可以修改的,直接使用 sys 模块中的 setrecursionlimit 函数来设置,这个函数接受一个参数,这个参数是新设置最大次数。...递归就是函数不断的调用自身,在内存中产生许多调用堆栈,这不就是传说中的数据结构——栈吗?...其中用循环实现这种方法并不通用,因为有些递归函数不能写成循环,比如阿克曼函数。下面我们直接来看使用 lru_cache 的效率。

    1.1K10

    Python 递归函数

    递归函数函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。...递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。...理论上,所有的递归函数都可以写成循环的方式,但循环的逻辑不如递归清晰。 ***使用递归函数需要注意防止栈溢出。...,所以,把循环看成是一种特殊的尾递归函数也是可以的。....html) 尾递归基于函数的尾调用, 每一级调用直接返回函数的返回值更新调用栈,而不用创建新的调用栈, 类似迭代的实现, 时间和空间上均优化了一般递归!

    1.3K30

    Python 递归函数

    递归函数函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。 举个例子,我们来计算阶乘 n!...于是,fact(n)用递归的方式写出来就是: 1 2 3 4 def fact(n): if n==1:   return 1 return n * fact(n - 1) 上面就是一个递归函数...))) ===> 5 * (4 * (3 * (2 * 1))) ===> 5 * (4 * (3 * 2)) ===> 5 * (4 * 6) ===> 5 * 24 ===> 120 递归函数的优点是定义简单...理论上,所有的递归函数都可以写成循环的方式,但循环的逻辑不如递归清晰。 使用递归函数需要注意防止栈溢出。...在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出。

    1.2K20

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券