Python实验3 函数与代码复用
目的:理解函数封装与递归思想
实验任务:
- 基础 :编写函数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("输入无效,请输入一个有效的整数。")
运行截图:

- 进阶 :用递归实现斐波那契数列(考虑添加缓存优化)。
源码:
用于存储已经计算过的斐波那契数
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("输入无效,请输入一个有效的非负整数。")
运行截图:

- 拓展 :科赫曲线正向、反向绘制,加入绘制速度、绘制颜色等额外功能
源码:
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 函数与代码复用的更多相关文章
- Python基础篇(三)_函数及代码复用
Python基础篇_函数及代码复用 函数的定义.使用: 函数的定义:通过保留字def实现. 定义形式:def <函数名>(<参数列表>): <函数体> return ...
- 函数和代码复用 --Python
1.关于递归函数的描述,以下选项中正确的是 A.包含一个循环结构 B.函数比较复杂 C.函数内部包含对本函数的再次调用 D.函数名称作为返回值 答案:D 答案解析:递归函数是指函数内部包含对本函数的再 ...
- Python学习笔记(五)函数和代码复用
函数能提高应用的模块性,和代码的重复利用率.在很多高级语言中,都可以使用函数实现多种功能.在之前的学习中,相信你已经知道Python提供了许多内建函数,比如print().同样,你也可以自己创建函数, ...
- 使用python对py文件程序代码复用度检查
#!/user/bin/env python # @Time :2018/6/5 14:58 # @Author :PGIDYSQ #@File :PyCheck.py from os.path im ...
- Python__函数和代码复用
主要内容 函数的定义和使用 实例:七段数码管的绘制 代码复用与函数递归 PyInstall库的使用 实例:科赫雪花小包裹 函数的定义与使用 函数的理解与定义 函数的使用及调用过程 函数的参数传递 函数 ...
- 我居然不知道Vue3可以使用hooks函数实现代码复用?
每天都要开心(▽)哇: 项目开发过程中,我们会遇到一些情况,就是多个组件都可以重复使用的一部分代码逻辑,功能函数,我们想要复用,这可怎么办呢? VUE2我们是怎么做的呢? 在vue2 中有一个东西:M ...
- python自定义pi函数的代码
下边内容是关于python自定义pi函数的内容. def pi(): # Compute digits of Pi. # Algorithm due to LGLT Meertens. k, a, b ...
- Python学习笔记6函数和代码复用
1.函数 (1)定义: (2)函数调用 (3)函数的参数传递 参数传递的两种方式:函数调用时,参数可以按照位置或名称的方式传递 (4)函数的返回值 (5)局部变量和全局变量 (6)lambda函数 2 ...
- Python语言程序设计基础(5)—— 函数和代码复用
lambda sum = lambda x,y : x + y print(sum(3,3),type(sum)) 默认参数 def prints(str,times = 2) : print(str ...
- Python中用函数实现代码的复用
# Python中用函数实现代码复用 """ def funcname(paras): statements return [expression] 关于函数定义说明如下 ...
随机推荐
- 推荐一款人人可用的开源 BI 工具,更符合国人使用习惯的数据可视化分析工具,数据大屏开发神器!
前言 今天大姚给大家推荐一款人人可用的开源.免费的 BI 工具,更符合国人使用习惯的数据可视化分析工具,数据大屏开发神器,Tableau.帆软的开源替代:DataEase. 工具介绍 DataEase ...
- ORACLE SELECT INTO 赋值为空,抛出 NO DATA FOUND 异常
例子: DECLARE ORDER_NUM VARCHAR2(20); BEGIN SELECT S.ORDER_NUM INTO ORDER_NUM FROM SALES_ORDER S WHERE ...
- keil优化等级说明 keil code optimization
其中 0级(Constan folding)的优化包括: a.常数折叠:只要有可能,编译器就执行将表达式化为常数数字的计算,其中包括运行地址的计算. b. 简单访问优化:对8051系统的内部数据和位地 ...
- QT5笔记:1.UI文件设计与运行机制
1.UI文件设计与运行机制 参考视频:https://www.bilibili.com/video/BV1AX4y1w7Nt #include "widget.h" #includ ...
- 大数据之路Week10_day01 (练习:通过设计rowkey来实现查询需求)
1.准备数据 链接:https://pan.baidu.com/s/1fRECXp0oWM1xgxc0uoniAA 提取码:4k43 2.需求如下 (1)查询出10条某个人的最近出现的位置信息 (2) ...
- rust学习笔记(3)
变量 变量默认是不可变的 不能使用没有初始化的变量 作用域 变量离开作用域之后会直接释放, 无法再次使用; 在内部代码块中定义的变量会导致外部的变量被遮蔽 类型转换 部分类型可以隐式转换, 部分类型需 ...
- js回忆录(4) -- 对象,构造函数
1.对象 && 构造函数 js是一门基于对象的语言,里边所有的数据类型都可以当对象使唤(当然null和undefined除外),当我们在v8引擎里声明一个对象时会发现每个对象属性里边都 ...
- gin解决CORS跨域问题
直接设置跨域参数 新建 cors 文件 package cors import ( "time" "github.com/gin-contrib/cors" & ...
- go 整分钟开始执行程序
前言 有时候我们的程序要求整分钟开始运行,这时候就需要对当前时间进行判断 package main import ( "fmt" "time" ) func m ...
- Golang 入门 : 符文
字符串常用语表示一系列文本字符,而Go的符文(rune)则用于表示单个字符. 字符串字面量由双引号(")包围,但rune字面量由单引号(')包围. Go程序几乎可以使用地球上任何语言的任何字 ...