Python语言程序设计(MOOC崇天)第五章函数和代码复用学习笔记(七段数码管绘制+科赫雪花小包裹)

复习:

今日内容:

扫描二维码关注公众号,回复: 3715600 查看本文章

  • 函数的定义与使用:

  • 函数的使用及调用过程

 

  • 参数传递的两种方式:

 

  •  局部变量和全局变量

如果在函数内部真实创建呢?

      组合数据类型是指针来体现的,如果函数中没有真实的创建组合数据类型,它使用的变量是指针,而指针指向的是外部的全局变量。

总结

标准数据类型

Python3 中有六个标准的数据类型:

  • Number(数字)
  • String(字符串)
  • List(列表)
  • Tuple(元组)
  • Set(集合)
  • Dictionary(字典)

Python3 的六个标准数据类型中:

  • 不可变数据(3 个):Number(数字)、String(字符串)、Tuple(元组);
  • 可变数据(3 个):List(列表)、Dictionary(字典)、Set(集合)。

总结:

实例:

七段数码管

#数码光绘制
import turtle
import time as T

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)) #通过eval()函数将数字变为整数


def main():
    turtle.setup(800, 350, 200, 200)
    turtle.penup()
    turtle.fd(-300)
    turtle.pensize(5)
    t = T.gmtime()
    s = T.strftime("%Y%m%d", t)
    drawDate(s)
    turtle.hideturtle()
    turtle.done()

main()

 

 

#数码光绘制
import turtle
import time as T

def drawGap(): #绘制数码管间隔
    turtle.penup()
    turtle.fd(5)

def drawLine(draw):#绘制单段数码管
    drawGap()
    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):
    turtle.pencolor("red")
    for i in date:
        if i == '-':
            turtle.write('年', font=("Arial", 28, "normal"))
            turtle.pencolor("green")
            turtle.fd(40)
        elif i =='=':
            turtle.write('月',font=("Arial", 28, "normal"))
            turtle.pencolor("blue")
        elif i=='+':
            turtle.write('日', font=("Arial", 28, "normal"))
        else:
            drawDigit(eval(i)) #通过eval()函数将数字变为整数


def main():
    turtle.setup(800, 350, 200, 200)
    turtle.penup()
    turtle.fd(-300)
    turtle.pensize(5)
    s = T.strftime("%Y-%m=%d+", T.gmtime())
    drawDate(s)
    turtle.hideturtle()
    turtle.done()

main()

  • 代码复用于函数递归

代码复用与模块化设计

递归:

递归实现:

字符串反转

斐波拉契数列

汉诺塔问题(递归的最经典例子)

#将字符串反转后输出
def rvs(s):
    if s == "":
        return s
    else:
        return rvs(s[1:])+s[0]



#斐波拉契数列

def f(n):
    if n == 1 or n == 2:
        return 1
    else:
        return f(n-1) + f(n-2)

#汉诺塔问题

count =0
def  hanoi(n, src, dst, mid):
    global count
    if n == 1:
        print("{}:{}->{}".format(1, src, dst))
        count += 1
    else:
        hanoi(n-1, src, mid, dst)
        print("{}:{}->{}".format(n, src, dst))
        count += 1
        hanoi(n-1, mid, dst, src)
def main():
    # c = input("input:")
    # print(rvs(c))
    # i = eval(input("输入数字:"))
    # print(f(i))
    hanoi(3, "A", "C", "B")
    print(count)
main()

总结:

关于递归的问题,说实话这里老师讲的很清楚,就是知道链条和基例就好,中间的步骤显得不那么重要,好比汉诺塔问题,就是的,我们是把n-1放到中间棍,将第n个放到目标棍,最后将n-1放到目标棍上,我们关心,n-1和n的关系。

  • PyInstaller库的使用

可执行文件去执行代码。而不是源文件

pip install pyinstaller

实例:科赫雪花小包裹

作业:

可以写多个return 语句 但是遇到第一个就会返回,结束函数的调用。没毛病。

猜你喜欢

转载自blog.csdn.net/qq_37791134/article/details/83186964