Python函数02

递归

1x2x3x4x5x6x7x8x9x10

def fact(n):
    if n==0:
        return 1
    else:
        return n*fact(n-1)
num=eval(input("请输入一个整数:"))
print(fact(abs(int(num))))
请输入一个整数:10
3628800

倒序输出字符串

def reverse(s):
    if s== "":
        return s
    else:
        return reverse(s[1:])+s[0]
str=input("请输入一个字符串:")
print(reverse(str))
请输入一个字符串:唐诗宋词
词宋诗唐

小测试

下列不是递归程序特点的是()
A:书写简单
B:一定要有基例
C:执行效率高
D:思路简单,代码不一定容易理解

答案选 C

实例 科赫曲线绘制

import turtle
def koch(size,n):
    if n== 0:
        turtle.fd(size)
    else:
        for angle in [0,60,-120,60]:
            turtle.left(angle)
            koch(size/3,n-1)
def main():
    turtle.setup(800,400)
    turtle.speed(1000) # 控制绘制速度
    turtle.penup()
    turtle.goto(-300,-50)
    turtle.pendown()
    turtle.pensize(2)
    koch(300,3) # 科赫曲线长度,阶数
    turtle.hideturtle()
main()

0阶科赫曲线
在这里插入图片描述

1阶科赫曲线
在这里插入图片描述

2阶科赫曲线
在这里插入图片描述

3阶科赫曲线
在这里插入图片描述

4阶科赫曲线
在这里插入图片描述
5阶科赫曲线
在这里插入图片描述

实例 绘制雪花

import turtle
def koch(size,n):
    if n== 0:
        turtle.fd(size)
    else:
        for angle in [0,60,-120,60]:
            turtle.left(angle)
            koch(size/3,n-1)
def main():
    turtle.setup(600,600)
    turtle.speed(10000000) # 控制绘制速度
    turtle.penup()
    turtle.goto(-200,100)
    turtle.pendown()
    turtle.pensize(2)
    level=4
    koch(400,level) 
    turtle.right(120)
    koch(400,level) 
    turtle.right(120)
    koch(400,level) 
    turtle.hideturtle()
main()

在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据攻城小狮子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值