函数的递归及科赫曲线绘制

函数的递归及科赫曲线绘制

1 递归的定义

递归:在函数中调用自己本身
在这里插入图片描述
阶乘的例子表现了递归的两个特征:
1、存在一个或多个基例,基例不需要再次递归,它是确定的表达式
2、所有递归链要已一个或多个基例结尾

2 递归的使用方法

阶乘的计算

根据用户输入的整数n,计算并输出n的阶乘值(本例n取10,12.56两种形式数值)
定义fact()函数
在这里插入图片描述

在这里插入图片描述
fact()函数通过if语句给出n为0的基例,当n==0时,fact()函数返回数值1,不再递归;n!=0时,通过递归返回n与n-1阶乘的乘积
负数和小数则通过abs()与int()函数将对应数值转换为非负整数

注意:若基例的构建错误则递归无法返回将会报错**

字符串的反转

输入字符串n ,输出反转后的字符串
错例如下图

在这里插入图片描述
此错误表明系统无法执行reverse()函数创建的递归
reverse()函数没有基例,递归层数超过最大(默认情况为1000),此时需通过下面的代码设定一个新的递归层数在这里插入图片描述
上面的方法较为麻烦,可以通过设置基例为最短形式(空字符串)来进行
正确代码为下图
在这里插入图片描述

科赫曲线绘制

形状类似雪花,也称雪花曲线在这里插入图片描述

科赫曲线的基本概念和绘制方法如下:

正整数n代表科赫曲线的阶数,表示生成科赫曲线过程的操
作次数。科赫曲线初始化阶数为0,表示一个长度为L的直线。
对于直线L,将其等分为三段,中间一段用边长为L/3的等边三
角形的两个边替代,得到1阶科赫曲线,它包含四条线段。进
一步对每条线段重复同样的操作后得到2阶科赫曲线。继续重
复同样的操作n次可以得到n阶科赫曲线。

一阶科赫曲线

在这里插入图片描述

n阶科赫曲线的雪花效果

在这里插入图片描述

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
递归函数是一种函数在其定义中直接或间接地调用自身的方式。用于绘制科赫雪花曲线(Koch Snowflake)的递归算法是一个典型的例子。这个过程通过三个步骤完成: 1. **基本形状**:首先,我们画出一个等边三角形,这是最简单的迭代段。 2. **分段**:对于每个三角形的边,我们将它分成三部分,并向内弯曲90度。对这三部分应用相同的递归操作,即再次绘制科赫曲线。 3. **重复**:重复步骤2,但每次迭代都会减少原边长的三分之一,直到达到预定的终止条件,比如边长小于某个阈值或达到了预设的迭代次数。 递归函数的核心思路就是定义一个基本情况(如三角形),然后处理一般情况(将每条边分为三等份并弯曲)。下面是Python一个简单的递归函数示例: ```python def koch_snowflake(size, depth=0): if depth == 0: # 基本情况,绘制原始三角形 draw_triangle(size) else: # 递归情况,处理每条边 for _ in range(4): # 因为有三条边,所以循环四次 new_size = size / 3 koch_snowflake(new_size, depth - 1) # 实际的绘图函数需要你自己实现 def draw_triangle(size): # 这里只是简单地描述如何绘制,你需要根据你的图形库进行调整 print("绘制一个边长为{}的小三角形".format(size)) # 调用函数,设置大小和深度 koch_snowflake(100, 5) # 可以改变第一个参数来控制曲线的细节程度 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值