目的:理解函数封装与递归思想

实验任务:

  1. 基础 :编写函数cal_factorial(n)计算阶乘(循环实现)。

    源码:

    def cal_factorial(n):

    result = 1

    for i in range(1, n + 1):

    result *= i

    return result

从控制台获取输入

try:

number = int(input("请输入一个整数来计算它的阶乘: "))

if number < 0:

print("负数没有阶乘,请输入一个非负整数。")

else:

factorial = cal_factorial(number)

print(f"{number} 的阶乘是: {factorial}")

except ValueError:

print("输入无效,请输入一个有效的整数。")

运行截图:

  1. 进阶 :用递归实现斐波那契数列(考虑添加缓存优化)。

    源码:

用于存储已经计算过的斐波那契数

fib_cache = {}

def fibonacci(n):

"""

此函数使用递归和缓存优化来计算斐波那契数列的第 n 项。

:param n: 要计算的斐波那契数列的位置

:return: 斐波那契数列的第 n 项的值

"""

# 检查是否已经计算过该值

if n in fib_cache:

return fib_cache[n]

# 基本情况

if n == 0 or n == 1:

result = n

else:

# 递归计算

result = fibonacci(n - 1) + fibonacci(n - 2)

# 将计算结果存入缓存

fib_cache[n] = result

return result

if name == "main":

try:

# 从控制台获取用户输入

n = int(input("请输入要计算斐波那契数列的位置(非负整数): "))

if n < 0:

print("输入无效,请输入一个非负整数。")

else:

# 调用函数计算斐波那契数

result = fibonacci(n)

print(f"斐波那契数列的第 {n} 项是: {result}")

except ValueError:

print("输入无效,请输入一个有效的非负整数。")

运行截图:

  1. 拓展 :科赫曲线正向、反向绘制,加入绘制速度、绘制颜色等额外功能

    源码:

    import turtle

def koch(t, order, size, speed, color):

t.speed(speed)

t.pencolor(color)

if order == 0:

t.forward(size)

else:

koch(t, order - 1, size / 3, speed, color)

t.left(60)

koch(t, order - 1, size / 3, speed, color)

t.right(120)

koch(t, order - 1, size / 3, speed, color)

t.left(60)

koch(t, order - 1, size / 3, speed, color)

def draw_koch_snowflake(order, size, speed, color, is_reverse=False):

t = turtle.Turtle()

screen = turtle.Screen()

if is_reverse:

t.right(180)

for _ in range(3):

koch(t, order, size, speed, color)

t.right(120)

screen.exitonclick()

正向绘制雪花示例

draw_koch_snowflake(order=3, size=300, speed=3, color="blue", is_reverse=False)

反向绘制雪花示例

draw_koch_snowflake(order=3, size=300, speed=3, color="red", is_reverse=True)

正向运行截图:

反向绘制运行截图:

Python实验3 函数与代码复用的更多相关文章

  1. Python基础篇(三)_函数及代码复用

    Python基础篇_函数及代码复用 函数的定义.使用: 函数的定义:通过保留字def实现. 定义形式:def <函数名>(<参数列表>): <函数体> return ...

  2. 函数和代码复用 --Python

    1.关于递归函数的描述,以下选项中正确的是 A.包含一个循环结构 B.函数比较复杂 C.函数内部包含对本函数的再次调用 D.函数名称作为返回值 答案:D 答案解析:递归函数是指函数内部包含对本函数的再 ...

  3. Python学习笔记(五)函数和代码复用

    函数能提高应用的模块性,和代码的重复利用率.在很多高级语言中,都可以使用函数实现多种功能.在之前的学习中,相信你已经知道Python提供了许多内建函数,比如print().同样,你也可以自己创建函数, ...

  4. 使用python对py文件程序代码复用度检查

    #!/user/bin/env python # @Time :2018/6/5 14:58 # @Author :PGIDYSQ #@File :PyCheck.py from os.path im ...

  5. Python__函数和代码复用

    主要内容 函数的定义和使用 实例:七段数码管的绘制 代码复用与函数递归 PyInstall库的使用 实例:科赫雪花小包裹 函数的定义与使用 函数的理解与定义 函数的使用及调用过程 函数的参数传递 函数 ...

  6. 我居然不知道Vue3可以使用hooks函数实现代码复用?

    每天都要开心(▽)哇: 项目开发过程中,我们会遇到一些情况,就是多个组件都可以重复使用的一部分代码逻辑,功能函数,我们想要复用,这可怎么办呢? VUE2我们是怎么做的呢? 在vue2 中有一个东西:M ...

  7. python自定义pi函数的代码

    下边内容是关于python自定义pi函数的内容. def pi(): # Compute digits of Pi. # Algorithm due to LGLT Meertens. k, a, b ...

  8. Python学习笔记6函数和代码复用

    1.函数 (1)定义: (2)函数调用 (3)函数的参数传递 参数传递的两种方式:函数调用时,参数可以按照位置或名称的方式传递 (4)函数的返回值 (5)局部变量和全局变量 (6)lambda函数 2 ...

  9. Python语言程序设计基础(5)—— 函数和代码复用

    lambda sum = lambda x,y : x + y print(sum(3,3),type(sum)) 默认参数 def prints(str,times = 2) : print(str ...

  10. Python中用函数实现代码的复用

    # Python中用函数实现代码复用 """ def funcname(paras): statements return [expression] 关于函数定义说明如下 ...

随机推荐

  1. oracle19.3打补丁

    补丁 36582781 - 数据库发布更新 19.24.0.0.240716 本文档在发布时准确无误.有关数据库版本更新 19.24.0.0.240716 的任何更改和其他信息,请参阅 My Orac ...

  2. Python实战:为Prometheus开发自定义Exporter

    Python实战:为Prometheus开发自定义Exporter 在当今的微服务架构和容器化部署环境中,监控系统的重要性不言而喻.Prometheus作为一款开源的系统监控和警报工具,以其强大的功能 ...

  3. Q:xml 需要转义的字符

    XML实体中不允许出现"&","<",">"等特殊字符,否则XML语法检查时将出错,如果编写的XML文件必须包含这些字符 ...

  4. 四柱汉诺塔的 Frame-Stewart 算法及其最优性

    注:本文基本上是对参考文献 \(1\) 的翻译.这份论文是法语的,并且我没找到英语版本或中文介绍( 大家应该很熟悉汉诺塔了把,,,这里就不解释三柱汉诺塔了. Frame-Stewart 算法 对于有 ...

  5. 使用-数据湖Iceberg和现有hive数仓打通并使用

    一.集群配置 1.版本使用 技术 版本 iceberg 1.3.1 flink 1.16.1 spark 3.2.1 hive 2.3.7 dlc-presto 待定 2.集群配置调整 (1)使用hi ...

  6. datawhale-leetcode打卡:001-012题

    这次这十二个题目属于是极限肝出来的,有两个参考了一下题解,还是很有意思.我会按照我个人的感觉去写这个东西. 螺旋矩阵(leetcode 054) 这个题目比较恶心的就是跑圈的过程怎么描述.首先,顺时针 ...

  7. kubernetes 集群中部署 nginx 服务

    kubernetes 部署nginx服务 本章节将介绍如何在kubernetes集群中部署一个nginx服务,并且能够对其进行访问. Namespace Namespace是kubernetes系统中 ...

  8. 嵌入式linux下的FTP服务器配置记录

    嵌入式linux FTP服务器 一般嵌入式Linux下的FTP服务器会有什么要求呢?一般来说差不多如下所示 账号认证,需要特定用户才能访问(不一定要和登录用户挂钩) 根目录固定在一个固定的位置,且不能 ...

  9. [CF901D] Weighting a Tree 题解

    想象力惊人的想到生成树,因此对于一种 \(c\) 序列,容易求出只有根不满足要求的构造,且只有树边有权.考虑通过非树边们修改根. 对于一条非树边(都是返祖边),假如我们给它的权值 \(+1\),那么对 ...

  10. Nginx - [02] 安装部署&配置

    官网下载地址:http://nginx.org/en/download.html 001 || 安装[windows] 解压之后,在命令提示符窗口启动nginx.exe 在浏览器访问80端口:loca ...