第 5 课 函数、作用域与递归

第 5 课 函数、作用域与递归

注意标准库文档入门教程

课程纲要

变量

  • 函数(必须掌握):接收输入、提供输出的东西

    • 关键字def 与参数:定义一个 echo()(回声),参数、默认参数和关键字参数

    • 返回值和 return 语句:

    • def function_name:
      do_something()
        return something 
    • None 值:NoneType数据类型,如果你不返回任何值。(type)

    • 诀窍:一个函数最好不要超过40行。

  • 作用域(掌握思想):

    • 起因:公用私用问题,保护数据。尽量不要使用全局变量。
    • 规则(不应该背下来):
    • 局部变量不能在全局作用域内使用
    • 局部作用域不能使用其他局部作用域内的变量
    • 全局变量可以在局部作用域中读取
    • global 关键字
  • 递归(掌握如何写递归函数):函数自己调用自己

    • 例子:

    • 从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?「从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?『从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?……』」

    • 直播例子

    • 数学归纳法:

      • 证明 「第一张骨牌会倒。」
      • 证明 「只要任意一张骨牌倒了,其下一张骨牌也会因為前面的骨牌倒而跟著倒。」
      • 则可下结论:所有的骨牌都会倒下。
    • 如何写递归函数:

    • 确定初始条件和函数的作用

    • 由"情况 n" 变化到"情况 n+1"

    • 确定递归结束的条件

    • 题目:

    • 斐波那契数列 用递归做太慢,只借鉴思路。

    • 递归乘法

课后作业

  • 定义一个gcd(m, n)函数,该函数可以求出m与n的最大公约数,用辗转相除法递归实现。
  • 用递归实现阶乘函数factorial(n),对于任意的整数n都能返回其对应的阶乘。
  • 跳水板

第 4 课 计算的本质

第 4 课 计算的本质

上次的课后作业

:如果你不理解视频里的内容,不要反复观看试图理解,不懂的先去群里问,或者去看答案,重要的是去练习,我们不能从概念到概念,而是应该从实践(解决问题),然后再结合理论知识。

只有实践的经验才会转换为你的编程能力。

  1. 程序要满足:输入分数 x (0 < x < 100),程序输出分数对应的等级:x < 60 不及格,60 < x < 80 及格,80 < x < 90 良好,90 < x < 100 优秀。

    scope = float(input("the scope euquals to "))
    if scope < 60:
       print("不及格")
    elif 60 <= scope < 80:
       print("及格")
    elif 80 <= scope < 90:
       print("良好")
    elif 90 <= scope <= 100:
       print("优秀")
  2. 程序要满足:首先输入一个整数 n ,然后程序连续接受输入 n 个数字,最终程序输出 n 个数字的平均值。

    n = int(input("n = "))
    total = 0.0
    for i in range(n):
       total += float(input())
    print("the average value is {0}".format(total / n))
  3. 左旋转字符串

    class Solution(object):
       def reverseLeftWords(self, s, n):
           """
           :type s: str
           :type n: int
           :rtype: str
           """
           # s n
           return s[n:] + s[0:n]
  4. 一维数组的动态和

    class Solution:
       def runningSum(self, nums):
           """
           :type nums: List[int]
           :rtype: List[int]
           """
           if nums is None:
               return []
           for i in range(1, len(nums)):
               nums[i] = nums[i] + nums[i-1]
           return nums

课程纲要

计算的本质:符号、模型、数黄瓜的故事。

  • 现实:左边4根黄瓜,右边2根黄瓜

  • 符号:

    • 4 + 2
    • 四 加 二
    • 肆 加 贰
    • 叽里 哼哈 呱啦
  • 模型:10 根手指、画“正”字、算盘…… (可操作模型)

  • 计算图模型:更加本质的模型。加法器:具体怎么计算我们并不关心。函数1

  • 表达式:(2 + 4) * 3 函数2

    • 数字是表达式;递归

    • 表达式 + 表达式。两个表达式相加是表达式;

    • 表达式 - 表达式。两个表达式相减是表达式;

    • 表达式 * 表达式。两个表达式相乘是表达式;

    • 表达式 / 表达式。两个表达式相除是表达式;

    (即构成表达式 运算符 表达式 的顺序的式子是表达式)

    • 图示 表达式

    • 验证 (2 + 4) * 3 是表达式

    • 变量与赋值

    • 表达式 (2 + 4) * 7 + ((12 - 3) * 6) / 2 过于复杂;

    • 用名字代表中间的过程,例如:爸爸的妹妹的老公,叫做「姑丈」;

    • a = (2 + 4) 原式 = a * 3

  • 函数:t -> 2*t

    function1

    function2 (1)

  • 参数和变量

    变量

  • 函数:有名字的运算过程

    a = 2 + 4

    f = t -> t * 2

    f(t) = t * 2

  • 函数调用 f(2)

  • 分支

    branch

    t -> if (t < 22) 
       {
         "hotpot"
       }
       else 
       {
         "ice cream"
       }
  • 变量的类型,不同的符号有不同的用途

    • 4 + 2 ( 数字 )
    • 四 加 二 、肆 加 贰 、兔子、鸡、abc、21411 (字符串)
    • 是,否 (布尔型)
  • 抽象:屏蔽具体的细节和步骤,只考虑输入和输出。例如:出租车司机的案例、圆的面积公式 pi*r^2

  • 注:本篇文章的内容大部分来源于 https://www.yinwang.org/blog-cn/2018/04/13/computer-science

硬币计划

Coin-Project 硬币计划

起因是不想花太多时间去催作业了,导致我没空去做其他的,还有备课,还有就是提高大家的自觉性。我决定对改作业催作业收费,需要这两项服务的人自愿付费,不限制金额

当然我目的不是卸磨杀驴,课程结束后,我会把所有付款人和款项公示,并以集体的名义,将所有费用,捐赠给支付宝公益平台的免费午餐计划,同时你也可以自行进行捐款。

收费有很多好处:

  1. 避免有些同学自律性不足,中途退出或者不交作业。
  2. 不论是我还是大家,学习 Python 会更加有使命感。
  3. 贫困的孩子们可以多吃饱饭。

参加硬币计划的同学:不限制金额,请自己捐款,然后把截图给我,要带明确的个人标识嗷。复制下列口令到支付宝,即可参与捐款:

15我支持【免费午餐】爱心捐赠,一起来吧! http:/bU4S46I45X0长按苻制,去👉zhi[爱心]亻寸[爱心]宝👈首页进行搜索,参与爱心捐赠

捐款之后,请填写【腾讯文档】,确定你公示的名字。参与的同学以后作业请发送到 python[\at]benearyou.com (请把 [\at] 改成 @ ,才是真实邮箱,目的是防止垃圾邮件骚扰)

如果不参与:不影响正常上课,有问题仍然可以在群里答疑。只是不单独催作业改作业了,但你仍然可以看直播和其他人的作业对答案。

公示名单

捐赠人 金额(元)
Yulia Юлия 50
xpzoumeng 50
三十 66
喵不乖 66
乐子 20
Aimee 50
Robb 10
JonDoe297 50
总额 422

感谢你们的学习,让这个世界变得更好!

免费午餐计划简要介绍

捐款项目的地址:支付宝公益平台-以公益的方式,为世界带来更多平等的机会

免费午餐坚持“师生同食、就地取材、透明公开、村校联合”学校执行的四项基本原则,保障为孩子们提供安全、营养的免费午餐。

1、服务时间:长期

2、帮扶地区:全国

3、受助对象:我们开通了多渠道面向社会公众筹集善款,以一人一餐4元的标准为乡村学校孩子们提供免费午餐。若学校存在因学生贫困吃不上午饭、离家远无法回家吃饭、学校没有能力提供午餐等情况,可向免费午餐基金上交开餐申请。

第 3 课 控制流

第 3 课 控制流

不会的东西可以在群里提问、或搜索查看标准库文档入门教程

课程纲要

  1. 逻辑运算:三种逻辑运算是什么?

  2. 控制流的元素

    • 条件 True or False
      • 得出 bool 型的运算符。例如:== in 以及 bool 型的 and not or
      • 能转换为 bool 型的类型。例如: float 型的 0.0, int 型的 0, str 型的 ""(空字符串)都为 False
    • 代码块和缩进(使用四个空格)
      1. 缩进增加时,代码块开始。
      2. 代码块可以包含其他代码块。
      3. 缩进减少为零,或减少为外面包围代码块的缩进,代码块就结束了。
    • 程序顺序执行
  3. 控制流语句

    • 条件判断

      • if 语句

      • 格式:if condition :

      • 例子:如果明天不下雨,我就去外婆家。(用 print 模拟)

      • else 语句

      • 格式:else :

      • elif 格式: elif condition :

      • 例子:

        • 如果老师说交作业,小明就说放在家里了,否则他就写作业。(用 print 模拟)
        • 小明去买一个西瓜,如果看见西红柿,就买两个。(用 print 模拟)
      • goto 是什么?goto | 科普:程序跳转,顺序运行

    • 循环
      • while 循环
      • 格式:while condition :
      • 例子:男女朋友闹矛盾,女生要等他道歉敲门99下才开门。(用 print 模拟)
      • for 循环
      • for item in items :
      • range() ,len()方法
      • 例子:如何将一个字符串输出,使得每行按顺序打印该字符串中的字符。
      • 循环和条件的组合 break continue

课后作业

编程:

  1. 程序要满足:输入分数 x (0 < x < 100),程序输出分数对应的等级:x < 60 不及格,60 < x < 80 及格,80 < x < 90 良好,90 < x < 100 优秀。
  2. 程序要满足:首先输入一个整数 n ,然后程序连续接受输入 n 个数字,最终程序输出 n 个数字的平均值。

附录 程序流程图

if 语句

image-20201231155300630

elif 语句

image-20201231155543295

while 语句

image-20201231162057447

2021,新年随笔

QQ图片20210101003228

图片源于隋辨的手机

「理想主义者抑郁年」,我这样评价2020年。我们如同正在见证如此预言——「2019年是过去十年最糟糕的一年,却可能是未来十年最好的一年」。人们幡然醒悟:过去十年那种平稳有序的进步,才是人类史上的罕见现象。

「因为疫情」开始变为多数事物变化的理由,上半年我花了很多时间独处,趁着这次机会,我开始自己买菜,自己做饭,自己洗碗,做任何想要做的事。很多时候,我们没空跟自己相处,没空观察自己,以至于那么多行为和思维模式都在不经意间触发。下半年我去了北京,开始读研生活。我感慨:北京能人众多,为什么我没有早一点来到这里?

这一年我关注了很多主题:

  • 减脂、生酮饮食、健康
  • 两性道德发展
  • 工业社会以及现代性发展
  • 计算机体系知识
  • 多标签学习

这一年,我的世界模型慢慢变化。人类学家常会研究现存原始部落,以此判断一个人类现象是不是受文化因素影响而产生。我开始用猴子视角来看世界:如果没有人类社会,我们只是一只猴子,会更加幸福还是更加悲惨?

酋长说:「我们只是活着,守着本分,沿袭着先人的活法。我们从来不问为什么,从来不记录。在内心深处,我们知道自己的民族很古老,但我们好像没有办法测算时间的流逝。我父亲和祖父讲故事的时候都不会说出时间。这并不是说明他们忘了,或者搞不清楚。在他们看来,过去就是过去了。」

没有人能找到那个部落。这片大陆深处隐藏着多少个这样存在于空间与时间之外的部落我们不得而知。当你想自作聪明地将这一切赋予意义,「以个人的孤独对抗这个世界有组织的欺骗」,结果他们说,孤独是什么,我既没有听说过自由,也没有听说过孤独,那是你们那个世界的事情。

也许他们生活地更加自由呢?

我选择变得更为包容,开始理解、接纳而非看不见他人的观念。因为什么都不是理所当然的,男权社会不是,工业主义也不是,就连当下所流行的一切文化都不是。我不想只发展专业能力,不想只是成为一个专业的程序员或工程师。除了赚钱,人们应该看到自己所处的浪潮,而不只是甘心成为一个「工具人」。我开始去参加很多聚会,甚至比我本科期间参加的所有聚会还多,认识不同的人,去发现他人的生活观念,悄然自足。

现代性特征之一,就是目的与手段分离,娱乐和劳作分离。我们用衣物和语言区分了野蛮与文明,用避孕套分离了性与生育,用城市化解构了家族关系,用互联网拉开了人的距离。我们正处在一座庞然机器里,资本和计算机让每个人,都不可避免在这系统之中越陷越深。我的好奇心越发旺盛,所以,在新年我仍要继续探索和思考。

「当下腰悬木剑,身披敝袍,一人一雕,悄然西去,自此足迹所至,踏遍了中原江南之地。」2021 年我想如金庸小说一般,要思考,要继续学习,察看社会舞台剧本,要爱,要体验,也希望大家也能够继续学习、成长!

相关文章

  • 新年随笔(2020)
  • 新年随笔(2018)
  • 新年寄望

第 2 课 字符串和数据结构

第 2 课 字符串和数据结构

不会的东西可以在群里提问、或搜索查看标准库文档入门教程。( Ctrl + F )

课程纲要和笔记

  1. 数据结构
    • 复习变量
      • 变量是内存的名字,赋值过程就是名字的重新绑定。例子:a = 1 a = a + 1
    • 复习数据类型
      • int, float: + - * \ \\ %
      • str: + == replace() split() format() strip() notice:*
      • bool: or and not
      • str(), float(), int():特定的类型有特定的运算,所以需要进行类型转换。
  • 数据结构是什么以及意义是?
    • 上述数据类型是最基本的、不可分割的数据结构。例子:学生信息表:学号、身份证、姓名。
    • 由于内存的性质,我们需要把现实世界的数据用线性的结构表示。数据结构,要考虑其结构操作
  • list 列表
    • 数据:本质上是表格,线性排列,可以是任何类型,
    • 操作:
    • append() [] * n +
    • pop() pop(i)
    • array[i] = n
    • fruits.index(x)
    • 更多特性
  • tuple 不可变列表
  1. 字符串和文件读写
  • f = open(file_name, 'w', encoding="utf-8") f.close()
    • 如何存储文件?文件读写
    • 需要 close 因为操作系统的规定。
    • f.read() , f.readline()
    • f.write()
  1. 简要复习上一课的内容,解答作业
    1. 编写一个程序:能顺序地输入两个数,回车后,程序将在在屏幕上打印两个数分别加减乘除的结果,程序代码应该包括你的注释
    2. 编写一个程序:能先输入字符串 s,然后输入一个整数 n,程序将把 n 个字符串拼接打印出来。

课后作业

  1. 编程作业,程序满足:自定义一个list里面包含一些整数,自行对其进行增删改查操作,转换成str类型,按照utf-8编码输出为txt文件。

  2. 复制下列代码,并利用它在屏幕上打印出Google likes Python

L = [
    ['Apple', 'Google', 'Microsoft'],
    ['Java', 'Python', 'Ruby', 'PHP'],
    ['likes', 'dislikes', 'own']
]

附录

  • 注意:上课的时候突然卡壳了!readline() 在遇到行尾的时候返回空白字符串,转成bool型是False,正确的按行读取并且加载到数组中应该是这样:

    array = []
    with open("test.txt", "r", encoding="utf-8") as f:
      text = f.readline()
      array.append(text)
      while text:
          text = f.readline()
          array.append(text)
    print(array)
  • 上课代码

    if __name__ == '__main__':
      print("hello")
      a = 1
      a = a + 1
      a = "test"
    
      print(a.capitalize())
      print(a == b)
      user = input()
      age = input()
      welcome = "hello, {0}, {1}".format(user, age)
      print(welcome)
      b = "hello"
      n = int(input())
      #   integer
      #   int(n) * str(b)   --> str
      print(n * b)
      flag = True
      # not
      # not True = False
      # or
      # (bool) and (bool)
      print(flag and False)
    
      #   原子
      #   学生表 :学号(str or int)、身份证(str)、姓名(str)。
      #   学生表 : x1 学号身份证姓名
      #   学生表 : x2 学号身份证姓名
      #   图 1-256
      array = [2, "s", 1.16 ]
      a = [1, 9, 3]
      b = [2, 2,2]
      matrix = [
          a ,
          b ,
          [  2,3,5  ]
      ]
    
      array.append("hello")
      array = ["s"] * 9
    
      new_list = array + matrix
      print(new_list)
      new_list.pop(3)
    
      new_list[0] = "T"
    
      new_list.clear()
      print(new_list)
    
      print(new_list.index("s"))
      # (list) .index( )
    
      t1 = tuple([1, 2, 4, 5, 8])
    
      table = tuple(["monday", "tuesday"])
      print(table[0])
    
      string = "s12255122sw"
      #   []
      print(string[1:-2])
      print(string[-2:])
      #   gbk
      #   utf-8
      #   01010 -->  a
      #   01010 -->  b
      #
      f = open("test.txt", "w", encoding="utf-8")
      # r: read w:write
      f.write(string * 10)
      f.close()
    
      # array = []
      #
      with open("test.txt", "r", encoding="utf-8") as f:
          text = "2"
          while text:
              text = f.readline()
              array.append(text)
    
      print(array)
    
      a = float(input())
      b = float(input())
      print(a * b, a + b , a / b)
    
      s = input()
      n = int(input())
      print(n * s)