全国计算机等级考试二级Python(2021年9月)备考笔记 第五天

article/2025/1/6 19:33:38

文章目录

  • Python语言程序设计-嵩天老师(MOOC)听课笔记 第5周
    • 知识点一
      • 函数的定义
      • 函数的调用
      • 函数的调用过程
      • 参数个数
      • 可选参数传递
      • 可变参数传递
      • 参数传递的两种方式
      • 函数的返回值
      • 局部变量和全局变量
      • lambda函数
      • lambda函数的应用
    • 实例 七段数码管绘制
      • 问题分析
      • 举一反三
    • 知识点二
      • 代码复用
      • 模块化设计
      • 递归的定义
      • 递归的实现
      • 递归的调用过程
      • 字符串反转
      • 斐波那契数列
      • 汉诺塔问题
    • 知识点三
      • PyInstaller库概述
      • PyInstaller库的安装
      • 简单的使用
      • PyInstaller库常用参数
      • 使用举例
    • 实例 科赫雪花小包裹
      • 科赫雪花
      • 科赫雪花绘制小包裹(上)
      • 科赫雪花小包裹(下)
      • 举一反三
    • 课后练习题
      • 实例一 七段数码管绘制
      • 实例二 科赫雪花小包裹
      • 实例三 任意累积
      • 实例四 斐波那契数列计算
      • 实例五 汉诺塔问题
    • 第五周测验题目
      • 单项选择题
        • 第一题
        • 第四题
        • 第六题
        • 第八题
        • 第九题
      • 程序设计题
        • 第一题 随机密码生成
        • 第二题 连续质数计算

Python语言程序设计-嵩天老师(MOOC)听课笔记 第5周

知识点一

函数的定义

  • 函数是一段代码的表示
  • 函数是一段具有特定功能的、可重用的语句组
  • 函数是一种功能的抽象,一般函数表达特定功能
  • 两个作用:降低编程难度 和 代码复用
  • 函数是一段代码的表示
def <函数名>(<参数(0个或多个)>):<函数体>return <返回值>
  • 案例:计算n!
def fact(n):s=1for i in range(1,n+1):s*=ireturn s
  • y = f ( x ) y=f(x) y=f(x)
  • 函数定义时,所指定的参数是一种占位符
  • 函数定义后,如果不经过调用,不会被执行
  • 函数定义时,参数是输入、函数体是处理、结果是输出(IPO)

函数的调用

  • 调用是运行函数代码的方式
def fact(n):s=1for i in range(1,n+1):s*=ireturn s
  • 调用时要给出实际参数
  • 实际参数替换定义中的参数
  • 函数调用后得到返回值

函数的调用过程

在这里插入图片描述

参数个数

  • 函数可以有参数,也可以没有,但必须保留括号
def <函数名>():<函数体>return <返回值>
#例
def fact():print("我也是函数")

可选参数传递

  • 函数定义时可以为某些参数指定默认值,构成可选参数
def <函数名>(<非可选参数>,<可选参数>):<函数体>return <返回值>
  • 计算n!//m
def fact(n,m=1):s=1for i in range(1,n+1):s*=ireturn s//m
#例
>>>fact(10)
3628800
>>>fact(10,5)
725760

可变参数传递

  • 函数定义时可以设计可变数量参数,既不确定参数总数量
def <函数名>(<参数>,*b):<函数体>return <返回值>
  • 计算n!乘数
def fact(n,*b):    # '*b' 可变参数s=1for i in range(1,n+1):s*=ifor item in b:s*=itemreturn s
#例
>>>fact(10,3)
10886400
>>>fact(10,3,5,8)
435456000

参数传递的两种方式

  • 函数调用时,参数可以按照位置或名称方式传递
def fact(n,m=1):s=1for i in range(1,n+1):s*=ireturn s//m
#例
>>>fact(10,5)
725760	
>>>fact(m=5,n=10)
725760

函数的返回值

  • 函数可以返回0个或多个结果
  • r e t u r n return return保留字用来传递返回值
  • 函数可以有返回值,也可以没有,可以有 r e t u r n return return,也可以没有
  • 可以传递0个返回值,也可以传递任意多个返回值
def fact(n,m=1):s=1for i in range(1,n+1):s*=ireturn s//m,n,m
#例
>>>fact(10,5)
(725760,10,5)    #元组类型
>>>a,b,c=fact(10,5)
>>>print(a,b,c)
725760 10 5

局部变量和全局变量

n,s=10,100    #n和s是全局变量
def fact(n):    #fact()函数中的n和s是局部变量s=1for i in range(1,n+1):s*=ireturn s
print(fact(n),s)    #n和s是全局变量
#例
运行结果
>>>
>3628800 100
  • 规则1:局部变量和全局变量是不同变量
  • 局部变量是函数内部的占位符,与全局变量可能重名但不同
  • 函数运算结束后,局部变量被释放
  • 可以使用 g l o b a l global global保留字在函数内部使用全局变量
n,s=10,100  
def fact(n):    #fact()函数中s是局部变量与全局变量s不同s=1for i in range(1,n+1):s*=ireturn s    #此处局部变量s是3628800
print(fact(n),s)    #此处全局变量s是100
#运行结果
>>>
3628800 100
n,s=10,100
def fact(n):global s    #fact()函数中使用global保留字声明此处s是全局变量sfor i in range(1,n+1):s*=ireturn s    #此处s指全局变量s
print(fact(n),s)    #此处全局变量s被函数修改
#运行结果
>>>
362880000 362880000
  • 规则2:局部变量为组合数据类型且未创建,等同于全局变量
ls=["F","f"]    #通过使用[]真实创建了一个全局变量列表ls
def func(a):ls.append(a)    #此处ls是列表类型,未真实创建则等同于全局变量return
func("C")    #全局变量ls被修改
print(ls)
#运行结果
>>>
['F','f','C']
ls=["F","f"]    #通过使用[]真实创建了一个全局变量列表ls
def func(a):ls=[]ls.append(a)    #此处ls是列表类型,真实创建ls是局部变量return
func("C")    #全局变量ls被修改
print(ls)
  • 使用规则
  • 基本数学类型,无论是否重名,局部变量与全局变量不同
  • 可以通过 g l o b a l global global保留字在函数内部声明全局变量
  • 组合数据类型,如果局部变量未真实创建,则是全局变量

lambda函数

  • lambda函数返回函数名作为结果
  • lambda函数是一种匿名函数,即没有名字的函数
  • 使用lambda保留字定义,函数名是返回结果
  • lambda函数用于定义简单的能够在一行内表示的函数
<函数名>=lambda<参数>:<表达式>
等价于
def <函数名>(<参数>):<函数体>return <返回值>
>>>f=lambda x,y:x+y
>>>f(10,15)
25
>>>f=lambda:"lambda函数"
>>>print(f())
#lambda函数

lambda函数的应用

  • 谨慎使用lambda函数
  • lambda函数主要用作一些特定函数或方法的参数
  • lambda函数有一些固定使用方式,建议逐步掌握
  • 一般情况,建议使用def定义的普通函数

实例 七段数码管绘制

问题分析

  • 七段数码管绘制
    在这里插入图片描述
  • 需求:用程序绘制七段数码管,似乎很有趣
  • 该怎么做呢?
    turtle绘图体系 → \rightarrow 七段数码管绘制
  • 基本思路
  • 步骤1:绘制单个数字对应的数码管
  • 步骤2:获得一串数字,绘制对应的数码管
  • 步骤3:获得当前系统时间,绘制对应的数码管
  • 绘制单个数码管
  • 七段数码管由7个基本线条组成
  • 七段数码管可以有固定顺序
  • 不同数字显示不同的线条
  • 七段数码管绘制
import turtle
def drawline(draw):    #绘制单段数码管turtle.pendown() if draw else turtle.penup()turtle.fd(40)turtle.right(90)
def drawDigit(digit):    #根据数字绘制七段数码管drawLine(True) if digit in [2,3,4,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,1,3,4,5,6,7,8,9] else drawLine(False)drawLine(True) if digit in [0,2,3,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,2,6,8] else drawLine(False)turtle.left(90)drawLine(True) if digit in [0,4,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,2,3,5,6,7,8,9] else drawLine(False)drawLine(True) if digit in [0,1,2,3,4,7,8,9] else drawLine(False)turtle.left(180)turtle.penup()    #为绘制后续数字确定位置turtle.fd(20)    #为绘制后续数字确定位置
  • 步骤2:获取一段数字,绘制多个数码管
    在这里插入图片描述
import turtle
def drawLine(draw):    #绘制单段数码管turtle.pendown() if draw else turtle.penup()turtle.fd(40)turtle.right(90)
def drawDigit(digit):    #根据数字绘制七段数码管drawLine(True) if digit in [2,3,4,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,1,3,4,5,6,7,8,9] else drawLine(False)drawLine(True) if digit in [0,2,3,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,2,6,8] else drawLine(False)turtle.left(90)drawLine(True) if digit in [0,4,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,2,3,5,6,7,8,9] else drawLine(False)drawLine(True) if digit in [0,1,2,3,4,7,8,9] else drawLine(False)turtle.left(180)turtle.penup()turtle.fd(20)
def drawDate(date):for i in date:drawDigit(eval(i))
def main():turtle.setup(800,350,200,200)turtle.penup()turtle.fd(-300)turtle.pensize(5)drawDate('20181010')turtle.hideturtle()turtle.done()
main()

输出结果:
在这里插入图片描述

#优化
import turtle
def drawGap():    #绘制数码管间隔turtle.penup()turtle.fd(5)
def drawLine(draw):    #绘制单段数码管turtle.pendown() if draw else turtle.penup()turtle.fd(40)drawGap()turtle.right(90)
def drawDigit(digit):    #根据数字绘制七段数码管drawLine(True) if digit in [2,3,4,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,1,3,4,5,6,7,8,9] else drawLine(False)drawLine(True) if digit in [0,2,3,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,2,6,8] else drawLine(False)turtle.left(90)drawLine(True) if digit in [0,4,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,2,3,5,6,7,8,9] else drawLine(False)drawLine(True) if digit in [0,1,2,3,4,7,8,9] else drawLine(False)turtle.left(180)turtle.penup()turtle.fd(20)
def drawDate(date):for i in date:drawDigit(eval(i))
def main():turtle.setup(800,350,200,200)turtle.penup()turtle.fd(-300)turtle.pensize(5)drawDate('20181010')turtle.hideturtle()turtle.done()
main()

输出结果:
在这里插入图片描述

  • 步骤3:获取系统时间,绘制七段数码管
  • 使用time库获得系统当前时间
  • 增加年月日标记
  • 年月日颜色不同
import turtle,time
def drawGap():    #绘制数码管间隔turtle.penup()turtle.fd(5)
def drawLine(draw):    #绘制单段数码管turtle.pendown() if draw else turtle.penup()turtle.fd(40)drawGap()turtle.right(90)
def drawDigit(digit):    #根据数字绘制七段数码管drawLine(True) if digit in [2,3,4,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,1,3,4,5,6,7,8,9] else drawLine(False)drawLine(True) if digit in [0,2,3,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,2,6,8] else drawLine(False)turtle.left(90)drawLine(True) if digit in [0,4,5,6,8,9] else drawLine(False)drawLine(True) if digit in [0,2,3,5,6,7,8,9] else drawLine(False)drawLine(True) if digit in [0,1,2,3,4,7,8,9] else drawLine(False)turtle.left(180)turtle.penup()turtle.fd(20)
def drawDate(date):    #data为日期,格式为'%Y-%m=%d+'turtle.pencolor("red")for i in date:if i =='-':turtle.write('年',font=("Arial",18,"normal"))turtle.pencolor("green")turtle.fd(40)elif i =='=':turtle.write('月',font=("Arial",18,"normal"))turtle.pencolor("blue")turtle.fd(40)elif i =='+':turtle.write('日',font=("Arail",18,"normal"))else:drawDigit(eval(i))
def main():turtle.setup(800,350,200,200)turtle.penup()turtle.fd(-300)turtle.pensize(5)drawDate(time.strftime('%Y-%m=%d+',time.gmtime()))turtle.hideturtle()turtle.done()
main()

输出结果:
在这里插入图片描述

举一反三

  • 理解方法思维
  • 模块化思维:确定模块接口,封装功能
  • 规则化思维:抽象过程为规则,计算机自动执行
  • 化繁为简:将大功能变为小功能组合,分而治之
  • 应用问题的扩展
  • 绘制带小数点的七段数码管
  • 带刷新的时间倒计时效果
  • 绘制高级的数码管

知识点二

代码复用

  • 把代码当成资源进行抽象
  • 代码资源化:程序代码是一种用来表达计算的"资源"
  • 代码抽象化:使用函数等方法对代码赋予更高级别的定义
  • 代码复用:同一份代码在需要时可以被重复使用
  • 函数 和 对象 是代码复用的两种主要形式
  • 函数:将代码命名在代码层面建立了初步抽象
  • 对象:属性和方法 < a >.< b >和< a >.< b >() 在函数之上再次组织进行抽象

模块化设计

  • 分而治之
  • 通过函数或对象封装将程序划分为模块及模块间的表达
  • 具体包括:主程序、子程序和子程序间关系
  • 分而治之:一种分而治之、分层抽象、体系化的设计思想
  • 紧耦合 松耦合
  • 紧耦合:两个部分之间交流很多,无法独立存在
  • 松耦合:两个部分之间交流较少,可以独立存在
  • 模块内部紧耦合、模块之间松耦合

递归的定义

  • 函数定义中调用函数自身的方式
    在这里插入图片描述
  • 两个关键特征

在这里插入图片描述

  • 链条:计算过程存在递归链条
  • 基例:存在一个或多个不需要再次递归的基例
  • 类似数学归纳法
  • 数学归纳法
  • 证明当n取第一个值 n θ n_{\theta} nθ时命题成立
  • 假设当 n k n_k nk时命题成立,证明当 n = n k + 1 n=n_{k+1} n=nk+1时命题也成立
  • 递归是数学归纳法思维的编程体现

递归的实现

在这里插入图片描述

def fact(n):if n == 0:return 1else:return n*fact(n-1)
  • 函数+分支语句
  • 递归本身是一个函数,需要函数定义方式描述
  • 函数内部,采用分支语句对输入参数进行判断
  • 基例和链条,分别编写对应代码

递归的调用过程

在这里插入图片描述

字符串反转

  • 将字符串s反转后输出
>>>s[::-1]
  • 函数+分支结构
  • 递归链条
  • 递归基例
def rvs(s):if s == "":return selse:return rvs(s[1:])+s[0]

斐波那契数列

  • F(n)=F(n-1)+F(n-2)
  • 函数+分支结构
  • 递归链条
  • 递归基例
def f(n):if n == 1 or n==2return 1else:return f(n-1)+f(n-2)

汉诺塔问题

在这里插入图片描述

  • 函数+分支结构
  • 递归链条
  • 递归基例
count = 0
def hanoi(n,src,dst,mid):global countif n==1:print("{}:{}->{}".format(1,src,dst))count +=1else:hanoi(n-1,src,mid,dst)print("{}:{}->{}".format(n,src,dst))count +=1hanoi(n-1,mid,dst,src)
hanoi(3,"A","C","B")
print(count)
#输出结果
1:A->C
2:A->B
1:C->B
3:A->C
1:B->A
2:B->C
1:A->C
7

知识点三

PyInstaller库概述

  • 将.py源代码转换成无需源代码的可执行文件
    在这里插入图片描述
  • PyInstaller库是第三方库
  • 官方网站:http://www.pyinstaller.org
  • 第三方库:使用前需要额外安装
  • 安装第三方库需要使用pip工具

PyInstaller库的安装

  • (cmd命令行) pip install pyinstaller
    在这里插入图片描述
如果安装时出现错误"During handling of the above exception, another exception occurred:",可以参考这位博主的博客https://blog.csdn.net/qq_44838702/article/details/105049833

简单的使用

  • (cmd命令行) pyinstaller - F <文件名.py>
    在这里插入图片描述

PyInstaller库常用参数

在这里插入图片描述

使用举例

  • pyinstaller -i curve.ico -F SevenDigitsDrawV2.py
    在这里插入图片描述

实例 科赫雪花小包裹

科赫雪花

  • 高大上的分型几何
  • 分形几何是一种迭代的几何图形,广泛存在于自然界中
    在这里插入图片描述
  • 科赫曲线,也叫雪花曲线

在这里插入图片描述

  • 用Python绘制科赫曲线

在这里插入图片描述

科赫雪花绘制小包裹(上)

  • 科赫曲线的绘制

在这里插入图片描述

  • 递归思想:函数+分支
  • 递归链条:线段的组合
  • 递归基例:初始线段
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.penup()turtle.goto(-300,-50)turtle.pendown()turtle.pensize(2)koch(600,3)    #3阶科赫曲线,阶数turtle.hideturtle()
main()
  • 科赫曲线的绘制 → \rightarrow 科赫雪花的绘制
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.penup()turtle.goto(-200,100)turtle.pendown()turtle.pensize(2)level=3    #3阶科赫曲线,阶数koch(400,level)turtle.right(120)koch(400,level)turtle.right(120)koch(400,level)turtle.hideturtle()
main()

在这里插入图片描述

科赫雪花小包裹(下)

  • pyinstaller -i curve.ico -F KochDrawV2.py
    在这里插入图片描述
    在这里插入图片描述

举一反三

  • 分形几何千千万
  • 康托尔集、谢尔宾斯基三角形、门格海绵…
  • 龙形曲线、空间填充曲线、科赫曲线…
  • 函数递归的深入应用…

课后练习题

实例一 七段数码管绘制

题目描述:七段数码管是一种展示数字的有效方式。请用程序绘制当前系统时间对应的七段数码管,效果如下:
在这里插入图片描述
要去如下:
(1) 使用time库获得系统当前时间,格式如下:20190411
(2) 绘制对应的七段数码管‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
(3) 数码管风格不限‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬

代码如下:
import turtle as t
import time
def drawGap(): #绘制数码管间隔t.penup()t.fd(5)
def drawLine(draw):   #绘制单段数码管drawGap()t.pendown() if draw else t.penup()t.fd(40)drawGap()t.right(90)
def drawDigit(d): #根据数字绘制七段数码管drawLine(True) if d in [2,3,4,5,6,8,9] else drawLine(False)drawLine(True) if d in [0,1,3,4,5,6,7,8,9] else drawLine(False)drawLine(True) if d in [0,2,3,5,6,8,9] else drawLine(False)drawLine(True) if d in [0,2,6,8] else drawLine(False)t.left(90)drawLine(True) if d in [0,4,5,6,8,9] else drawLine(False)drawLine(True) if d in [0,2,3,5,6,7,8,9] else drawLine(False)drawLine(True) if d in [0,1,2,3,4,7,8,9] else drawLine(False)t.left(180)t.penup()t.fd(20)
def drawDate(date):t.pencolor("red")for i in date:drawDigit(eval(i))
def main():t.setup(800, 350, 200, 200)t.penup()t.fd(-300)t.pensize(5)drawDate(time.strftime('%Y%m%d',time.gmtime()))t.done()
main()

实例二 科赫雪花小包裹

题目描述:科赫曲线,也叫雪花曲线。绘制科赫曲线。在这里插入图片描述
请补充编程模板中代码,完成功能:获得用户输入的整数N,作为阶,绘制N阶科赫曲线。

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(level):turtle.setup(600,600)turtle.penup()turtle.goto(-200, 100)turtle.pendown()turtle.pensize(2)koch(400,level)     turtle.right(120)koch(400,level)turtle.right(120)koch(400,level)turtle.hideturtle()try:level = eval(input("请输入科赫曲线的阶: "))main(level)
except:print("输入错误")

实例三 任意累积

题目描述:请根据编程模板补充代码,计算任意个输入数字的乘积。‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
注意,仅需要在标注…的地方补充一行或多行代码。
输入示例:
1 , 2 , 3 , 4 1,2,3,4 1,2,3,4
输出示例:
24 24 24

def cmul(a, *b):m = afor i in b:m *= ireturn mprint(eval("cmul({})".format(input())))

实例四 斐波那契数列计算

题目描述:根据编程模板补充代码,计算斐波那契数列的值,具体功能如下:‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
1.获取用户输入整数 N N N,其中, N N N为正整数‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
2.计算斐波那契数列的值‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
如果将斐波那契数列表示为 f b i ( N ) fbi(N) fbi(N),对于整数 N N N,值如下:‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
f b i ( 1 ) fbi(1) fbi(1) f b i ( 2 ) fbi(2) fbi(2)的值是1,当 N > 2 N>2 N>2时, f b i ( N ) = f b i ( N − 1 ) + f b i ( N − 2 ) ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‮ ‬ ‫ ‬ ‫ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‮ ‬ ‭ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‮ ‬ ‫ ‬ ‫ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‮ ‬ ‭ ‬ ‫ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‮ ‬ ‪ ‬ ‮ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‮ ‬ ‪ ‬ ‭ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‮ ‬ ‫ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‪ ‬ ‮ ‬ ‪ ‬ ‫ ‬ fbi(N) = fbi(N-1) + fbi(N-2) ‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬ fbi(N)=fbi(N1)+fbi(N2)
请采用递归方式编写。
输入示例:
4 4 4
输出示例:
3 3 3

代码如下:
def fbi(n):if n == 1 or n == 2:return 1 else:return fbi(n-1) + fbi(n-2)n = eval(input())
print(fbi(n))

实例五 汉诺塔问题

题目描述:请补充编程模板中代码,完成如下功能:‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
有三个圆柱 A 、 B 、 C A、B、C ABC,初始时 A A A上有 N N N个圆盘,N由用户输入给出,最终移动到圆柱C上。‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
每次移动步骤的表达方式示例如下: [ S T E P 10 ] A − > C [STEP 10] A->C [STEP10]A>C。其中, S T E P STEP STEP是步骤序号,宽度为4个字符,右对齐。‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
请编写代码,获得输入 N N N后,输出汉诺塔移动的步骤。
输入格式:一个整数
输入示例:4
输出格式:每个步骤一行,每行参考格式如下: [ S T E P 10 ] A − > C [STEP 10] A->C [STEP10]A>C
输出示例:
[STEP 1] A->C
[STEP 2] A->B
[STEP 3] C->B
[STEP 4] A->C
[STEP 5] B->A
[STEP 6] B->C
[STEP 7] A->C

代码如下:
steps = 0
def hanoi(src, des, mid, n):global stepsif n == 1:steps += 1print("[STEP{:>4}] {}->{}".format(steps, src, des))else:hanoi(src, mid, des, n-1)steps += 1print("[STEP{:>4}] {}->{}".format(steps, src, des))        hanoi(mid, des, src, n-1)
N = eval(input())
hanoi("A", "C", "B", N)

第五周测验题目

单项选择题

第一题

在这里插入图片描述

第四题

在这里插入图片描述

第六题

在这里插入图片描述

第八题

在这里插入图片描述

第九题

在这里插入图片描述

程序设计题

第一题 随机密码生成

题目描述:补充编程模板中代码,完成如下功能:‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬以整数17为随机数种子,获取用户输入整数N为长度,产生3个长度为N位的密码,密码的每位是一个数字。每个密码单独一行输出。‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
产生密码采用random.randint()函数。
输入示例: 3 3 3
输出示例:
634 634 634
524 524 524
926 926 926

代码如下:
import randomdef genpwd(length):a = 10**(length-1)b = 10**length - 1return "{}".format(random.randint(a, b))length = eval(input())
random.seed(17)
for i in range(3):print(genpwd(length))

第二题 连续质数计算

题目描述:补充编程模板中代码,完成如下功能:‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬获得用户输入数字N,计算并输出从N开始的5个质数,单行输出,质数间用逗号,分割。‪‬‪‬‪‬‪‬‪‬‮‬‫‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‫‬
注意:需要考虑用户输入的数字N可能是浮点数,应对输入取整数;最后一个输出后不用逗号。
输入示例: 12 12 12
输出示例: 13 , 17 , 19 , 23 , 29 13,17,19,23,29 13,17,19,23,29

代码如下:
def prime(m):for i in range(2,m):if m % i == 0:return Falsereturn Truen = eval(input())
n_ = int(n)
n_ = n_+1 if n_ < n else n_
count = 5while count > 0:if prime(n_):if count > 1:print(n_, end=",")else:print(n_, end="")count -= 1 n_ += 1

http://chatgpt.dhexx.cn/article/q8tGIQBq.shtml

相关文章

Python语言程序设计笔记

例&#xff1a;获得用户输入数字N&#xff0c;计算并输出从N开始的5个质数&#xff0c;单行输出 首先&#xff1a;定义函数判断一个数是否是质数&#xff0c;return True/False&#xff0c;注意return True的格式&#xff0c;不在for循环体中&#xff0c;在函数体中(循环的高…

Python——函数和代码复用(模块4:PyInstaller库的使用)(实例:七段数码管绘制科赫雪花小包裹)

前言 本篇主要介绍函数和代码复用&#xff0c;以七段数码管绘制为例&#xff0c;介绍函数的定义和使用。以科赫雪花小包裹为例&#xff0c;介绍PyInstaller库的使用。 &#xff08;从本篇开始&#xff0c;出现的一些库中函数介绍以及部分简单代码都将以图片形式呈现&#xff0…

Python语言程序设计第五章

第五章 函数和代码复用 方法论 -Python基本代码抽象即函数的使用方法 实践能力 -学会编写带有函数并复用代码的程度 5.1 函数的定义与使用 1、函数的理解与定义 函数是一段代码的表示 -函数是一段具有特定功能的、可重用的语句组 -函数是一种功能的抽象&#xff0c;一般函数…

创意画板延伸内容

在完成了创意画板的基础功能实现后&#xff0c;我们就可以通过画板来绘制一些有趣的图形了 1.平面山脉图 效果图如上 山脉图是由一个个山峰构成的&#xff0c;所以先绘制一个山峰 而山峰的绘制算法是&#xff1a;先确定两个点A B&#xff0c;然后获取A B的中间点P&#xff0…

Java第六课——画图板

Java第六课——画图板 这节课画一个画图板&#xff0c;可以画线画圆&#xff0c;还可以通过递归画出好看的图案如&#xff1a;谢尔宾斯基三角形&#xff0c;康托尔方形集&#xff0c;甚至立体图门格海绵。 首先创建一个窗体。定义一个类和一个方法。 public class Draw{publ…

分形理论中的分维解析

最近打算利用一段时间好好学习一下分形理论&#xff0c;也写一系列博客记录下自己的学习归纳情况。下面是这部分文章的目录&#xff1a; 一、分形理论的历史过程 二、分形理论的基础概念 三、分形理论的分维解析 四、分形理论的Hausdorff维数 五、分形理论的盒维数 六、分形理论…

python绘制n阶科赫曲线线段_分形几何中科赫雪花的绘制

目录分形几何在自然界中广泛存在(康托尔集、谢尔滨斯基三角形、门格海绵、龙形曲线、科赫曲线...),实际上分形几何是一种迭代的几何图形。本文主要讨论科赫曲线。 科赫曲线的绘制: import turtle def koch(size,n):#绘制科赫曲线含俩个参数,大小和阶数 if n == 0:#基线情…

【计算几何】大自然的数学模型--分形几何

一、前言 分形几何是几何数学中的一个分支&#xff0c;也称大自然几何学&#xff0c;由著名数学家本华曼德勃罗&#xff08; 法语&#xff1a;BenoitB.Mandelbrot&#xff09;在 1975 年构思和发展出来的一种新的几何学。分形几何是对大自然中微观与宏观和谐统一之美的发现&…

Java分形递归——门格海绵

门格海绵的结构简单来说就是从一个正方体开始&#xff1b;再把正方体的每一个面分成9个正方形&#xff0c;这时就形成了由27个小正方体组成的一个大正方体&#xff1b;然后再把每一面的中间的正方体和最中心的正方体去掉&#xff0c;最终留下20个正方体。最后&#xff0c;把每一…

门格海绵的实现

实现效果&#xff1a; 源代码&#xff1a; package sponge;import java.awt.Color; import java.awt.Graphics; import java.awt.Graphics2D; import java.awt.Point; import java.awt.Polygon;import javax.swing.JFrame;public class Sponge_Main extends JFrame impleme…

混沌与分形(一):谢尔宾斯基三角形与门格海绵

研究混沌运动&#xff0c;少不了对分形理论的探讨。分形&#xff1a;通常被定义为“一个粗糙或零碎的几何形状&#xff0c;可以分成数个部分&#xff0c;且每一部分都&#xff08;至少近似地&#xff09;是整体缩小后的形状”&#xff0c;即具有自相似的性质。 本篇将从一维过…

分形之门格海绵

门格海绵解决思路&#xff1a; 1. 迭代如何实现 2. 立方体该怎么画 3. 实现门格海绵代码 4. 画图板门格海绵代码 1. 迭代如何实现 为了实现从1图—>2图—>3图效果,我们就要想到用迭代去实现. 因为像3图这样的图形,是由若干个2图这样的基本图形组成的 那么,怎样实现…

JAVA学习日志之门格海绵

门格海绵的结构可以用以下方法形象化&#xff1a; 从一个正方体开始。&#xff08;第一个图像&#xff09; 把正方体的每一个面分成9个正方形。这将把正方体分成27个小正方体&#xff0c;像魔方一样。 把每一面的中间的正方体去掉&#xff0c;把最中心的正方体也去掉&#xff0…

复杂分形,简单规则:门格海绵世界探秘

连绵的山川、飘浮的云朵、岩石的断裂口、布朗粒子运动的轨迹、树冠、花菜、大脑皮层……这些部分与整体以某种方式相似的形体&#xff0c;可以说&#xff0c;就是“分形”的要义了&#xff0c;也恰恰是这些“不规则的”、“分散的”、“支离破碎的”物体又重新让我们认识了自然…

JQData | 高校版使用教程,30秒安装完成,自带Python环境

本地量化金融数据JQData&#xff0c;是聚宽数据团队专门为金融机构、学术团体和量化研究者们提供的本地量化金融数据服务。自有版权&#xff0c;支持国内多家头部券商实盘交易。历经15万量化研究者与数百家机构使用验证。 JQData目前已支持国内30 高校&#xff0c;本次更新&…

JQData + matplotlib 实现回测日志的交易细节可视化 量化数据接口

原文&#xff1a;https://zhuanlan.zhihu.com/p/49051899 前言&#xff1a; 做量化交易的朋友都知道回测的重要性&#xff0c;回测结果是衡量一个量化交易策略是否靠谱的重要依据。回测平台会按历史行情数据模拟成交&#xff0c;并将回测结果汇总成报告。 在很多时候&#xf…

Note: Python学习笔记 -- Anaconda install jqdata

运行代码下列代码&#xff0c;提示错误 没有安装 jqdata。打开Anaconda Prompt 输入 pip install jqdata 提示cannot find command git然后百度了半天&#xff0c;有人说 pip install git 出错可以使用 conda install git 但是依然出错。最后去官网下载了Git:https://git-scm.…

jq使用教程01_最贴心教程,安装JQData全靠这篇指南

Hi, 各位亲爱的小伙伴们&#xff01; 近来听说有部分小伙伴在安装JQData时遇到了点小麻烦&#xff0c;导致最后没有安装成功&#xff0c;为了帮助小伙伴们快速成功安装JQData&#xff0c;小编今天来为大家排一下“雷”&#xff0c;希望能帮到你们哟 (&#xff65;ω&#xff6…

事件驱动的选股小工具(JQData)

昨天发改委下发了《关于积极推进风电、光伏发电无补贴平价上网有关工作的通知》&#xff0c;也不知道对股市是利空还是利多。连夜做了一个搜索公司经营范围的小工具,看看那些股票受到影响。 以后还可以增加筛选条件&#xff0c;比如财务指标&#xff0c;剔除ST股票&#xff0c;…

股票python量化交易008-JoinQuant中JQData的使用

查阅JoinQuant中JQData的使用文档python代码实现导入JQData,并认证用户身份。认证完毕显示“auth success”后即可使用 from jqdatasdk import *; auth(ID,Password);#ID是申请时所填写的手机号;Password为聚宽官网登录密码 # 查询jqdata的调用次数情况 surplus_count = g…