头歌-Python 基础

第1关:建模与仿真

  • 1、

    建模过程,通常也称为数学优化建模(Mathematical Optimization Modeling),不同之处在于它可以确定特定场景的特定的、最优化或最佳的结果。这被称为诊断一个结果,因此命名为▁▁▁。

    填空1答案:决策建议性分析

  • 2、

    字典里对仿真模拟的定义是指两个具体的过程:一是通过▁▁▁来表示系统如何工作,另一个是通过▁▁▁来检查问题。

    填空1答案:创建系统

    填空2答案:模拟现实情况

 第2关:脚本

  • 任务描述
  • 相关知识
    • 脚本的定义
    • 遍历数组
    • 求最大值
  • 编程要求
  • 测试说明

任务描述

本关任务:学习数学建模与仿真的脚本使用。

相关知识

本关是为了让大家掌握脚本的使用方法,为数学建模打下良好的基础。

脚本的定义

脚本(Script),是使用一种特定的描述性语言,依据一定的格式编写的可执行文件。

脚本可以理解为将一组代码进行封装,通过运行脚本可以非常方便的实现某一目标,省去了繁重的代码。

在数学建模比赛中,仅有三天时间,通过撰写脚本,可以节约大量时间。

图  1


脚本

遍历数组

通俗的理解,遍历数组就是:把数组中的元素都看一遍

示例如下:

 
  1. a=[1,2,3,4]
  2. def Traverse(a):
  3. for i in range(0,4):
  4. print(a[i])

输出:1,2,3,4

此时只需要通过引用 Traverse() 即可做到遍历数组。

求最大值

在 python 中,还有很多脚本可以直接使用,例如求最大值,最小值等。

建模过程中,我们通常要求一组数据的最大值,最小值等,从而求得问题的最优解。

例如,给出一组数据a=[1,3,5,2,5,6,8],在 python 中,可以直接使用 max 函数直接进行求解。

 
  1. a=[1,3,5,2,5,6,8]
  2. x=max(a)
  3. print(x)

编程要求

根据提示在右侧代码器中 Begin-End 区间补充代码,遍历数组并输出数组的最大值。

测试说明

平台会对你编写的代码进行测试:

测试输入:49151232; 预期输出: 4 91 51 2 32 最大值:91

arr = [4, 91, 51, 2, 32]
# 遍历num数组
########## begin ##########
print(arr)
##########  end  ##########
# 输出“最大值为:”
########## begin ##########
print("最大值:", max(arr))
##########  end  ##########

第3关:循环

  • 任务描述
  • 相关知识
    • 循环概览
    • Python While 循环语句
    • Python for 循环语句
    • Python 循环嵌套
    • Python break 语句
    • Python continue 语句
    • Python pass 语句
  • 编程要求
  • 测试说明

任务描述

本关任务:学习 Python 循环语句。

相关知识

为了完成本关任务,我们需要掌握:

  1. while 循环。
  2. for 循环。
  3. 循环嵌套。
  4. break 语句。
  5. continue 语句。
  6. pass 语句。
循环概览

在数学建模中,给定的数据集往往十分复杂,循环变成了处理数据必不可少的技能。

本节实训将向大家介绍 Python 的循环语句,程序在一般情况下是按顺序执行的。

编程语言提供了各种控制结构,允许更复杂的执行路径。

循环语句允许我们执行一个语句或语句组多次,下面是在大多数编程语言中的循环语句的一般形式:

Python 提供了 for 循环和 while 循环(在 Python 中没有 do..while 循环):

循环类型描述
while 循环在给定的判断条件为 true 时执行循环体,否则退出循环体。
for 循环重复执行语句
循环嵌套你可以在 while 循环体中嵌套 for 循环

循环控制语句

循环控制语句可以更改语句执行的顺序。Python 支持以下循环控制语句:

控制语句描述
break 语句在语句块执行过程中终止循环,并且跳出整个循环
continue 语句在语句块执行过程中终止当前循环,跳出该次循环,执行下一次循环
pass 语句pass 是空语句,是为了保持程序结构的完整性
Python While 循环语句

Python 编程中 while 语句用于循环执行程序,即在某条件下,循环执行某段程序,以处理需要重复处理的相同任务。其基本形式为:

 
  1. while 判断条件(condition):
  2. 执行语句(statements)……

执行语句可以是单个语句或语句块。判断条件可以是任何表达式,任何非零、或非空(null)的值均为 true。

当判断条件假 false 时,循环结束。

执行流程图如下:

图  1


执行流程图

看下面一个例子:

 
  1. count = 0
  2. while (count < 9):
  3. print 'The count is:', count
  4. count = count + 1
  5. print "Good bye!"

以上代码执行输出结果:

 
  1. The count is: 0
  2. The count is: 1
  3. The count is: 2
  4. The count is: 3
  5. The count is: 4
  6. The count is: 5
  7. The count is: 6
  8. The count is: 7
  9. The count is: 8
  10. Good bye!
Python for 循环语句

Python for 循环可以遍历任何序列的项目,如一个列表或者一个字符串。

语法:

for 循环的语法格式如下:

 
  1. for iterating_var in sequence:
  2. statements(s)

流程图:

图  1


for 循环流程图

一个例子:

 
  1. for letter in 'Python': # 第一个实例
  2. print("当前字母: %s" % letter)
  3. fruits = ['banana', 'apple', 'mango']
  4. for fruit in fruits: # 第二个实例
  5. print ('当前水果: %s'% fruit)
  6. print ("Good bye!")

以上实例输出结果:

 
  1. 当前字母: P
  2. 当前字母: y
  3. 当前字母: t
  4. 当前字母: h
  5. 当前字母: o
  6. 当前字母: n
  7. 当前水果: banana
  8. 当前水果: apple
  9. 当前水果: mango
  10. Good bye!
Python 循环嵌套

Python 语言允许在一个循环体里面嵌入另一个循环。

Python for 循环嵌套语法:

 
  1. for iterating_var in sequence:
  2. for iterating_var in sequence:
  3. statements(s)
  4. statements(s)

Python while 循环嵌套语法:

 
  1. while expression:
  2. while expression:
  3. statement(s)
  4. statement(s)

你可以在循环体内嵌入其他的循环体,如在 while 循环中可以嵌入 for 循环,反之,你可以在 for 循环中嵌入 while 循环。

实例:

以下实例使用了嵌套循环输出 2−100 之间的素数:

实例

 
  1. i = 2
  2. while(i < 100):
  3. j = 2
  4. while(j <= (i/j)):
  5. if not(i%j): break
  6. j = j + 1
  7. if (j > i/j) : print i, " 是素数"
  8. i = i + 1
  9. print "Good bye!"

以上实例输出结果:

 
  1. 2 是素数
  2. 3 是素数
  3. 5 是素数
  4. 7 是素数
  5. 11 是素数
  6. 13 是素数
  7. 17 是素数
  8. 19 是素数
  9. 23 是素数
  10. 29 是素数
  11. 31 是素数
  12. 37 是素数
  13. 41 是素数
  14. 43 是素数
  15. 47 是素数
  16. 53 是素数
  17. 59 是素数
  18. 61 是素数
  19. 67 是素数
  20. 71 是素数
  21. 73 是素数
  22. 79 是素数
  23. 83 是素数
  24. 89 是素数
  25. 97 是素数
  26. Good bye!
Python break 语句

Python break 语句,就像在 C 语言中,打破了最小封闭 for 或 while 循环。

break 语句用来终止循环语句,即循环条件没有 False 条件或者序列还没被完全递归完,也会停止执行循环语句。

break 语句用在 while 和 for 循环中。

如果您使用嵌套循环,break 语句将停止执行最深层的循环,并开始执行下一行代码。

Python 语言 break 语句语法:

break 举一个实例:

 
  1. for letter in 'Python': # 第一个实例
  2. if letter == 'h':
  3. break
  4. print '当前字母 :', letter
  5. var = 10 # 第二个实例
  6. while var > 0:
  7. print '当前变量值 :', var
  8. var = var -1
  9. if var == 5: # 当变量 var 等于 5 时退出循环
  10. break
  11. print "Good bye!"

以上实例执行结果:

 
  1. 当前字母 : P
  2. 当前字母 : y
  3. 当前字母 : t
  4. 当前变量值 : 10
  5. 当前变量值 : 9
  6. 当前变量值 : 8
  7. 当前变量值 : 7
  8. 当前变量值 : 6
  9. Good bye!
Python continue 语句

Python continue 语句跳出本次循环,而 break 跳出整个循环。

continue 语句用来告诉 Python 跳过当前循环的剩余语句,然后继续进行下一轮循环。

continue 语句用在 while 和 for 循环中。

Python 语言 continue 语句语法格式如下:

continue

实例:

 
  1. for letter in 'Python': # 第一个实例
  2. if letter == 'h':
  3. continue
  4. print '当前字母 :', letter
  5. var = 10 # 第二个实例
  6. while var > 0:
  7. var = var -1
  8. if var == 5:
  9. continue
  10. print '当前变量值 :', var
  11. print "Good bye!"

以上实例执行结果:

 
  1. 当前字母 : P
  2. 当前字母 : y
  3. 当前字母 : t
  4. 当前字母 : o
  5. 当前字母 : n
  6. 当前变量值 : 9
  7. 当前变量值 : 8
  8. 当前变量值 : 7
  9. 当前变量值 : 6
  10. 当前变量值 : 4
  11. 当前变量值 : 3
  12. 当前变量值 : 2
  13. 当前变量值 : 1
  14. 当前变量值 : 0
  15. Good bye!
Python pass 语句

Python pass 是空语句,是为了保持程序结构的完整性。

pass 不做任何事情,一般用做占位语句。

Python 语言 pass 语句语法格式如下:

pass 测试实例:

 
  1. # 输出 Python 的每个字母
  2. for letter in 'Python':
  3. if letter == 'h':
  4. pass
  5. print '这是 pass 块'
  6. print '当前字母 :', letter
  7. print "Good bye!"

以上实例执行结果:

 
  1. 当前字母 : P
  2. 当前字母 : y
  3. 当前字母 : t
  4. 这是 pass 块
  5. 当前字母 : h
  6. 当前字母 : o
  7. 当前字母 : n
  8. Good bye!

编程要求

根据提示在右侧代码器中 Begin-End 区间补充代码,填写正确语句即可过关。

测试说明

平台会对你编写的代码进行测试:

要求实现:

第一部分代码输出十以内的偶数,第二部分代码输出十以内的整数。

i = 1
while i < 10:
    i += 1
    if i % 2 > 0:  # 非双数时跳过输出
########## begin ##########
        continue
##########  end  ##########
    print(i)  # 输出双数2、4、6、8、10

i = 1
while 1:  # 循环条件为1必定成立
    print(i)  # 输出1~10
    i += 1
    if i > 10:  # 当i大于10时跳出循环
########## begin ##########
        break
##########  end  ##########

第4关:向量

  • 任务描述
  • 相关知识
    • python 向量的概念
    • 修改数组形状
      • numpy.reshape
    • 翻转数组
      • numpy.transpose
    • 修改数组维度
      • numpy.broadcast
    • 连接数组
      • numpy.concatenate
    • 分割数组
      • numpy.split
    • 数组元素的添加与删除
      • numpy.resize
  • 编程要求
  • 测试说明

任务描述

本关任务:学习数学建模中有关向量的知识。

相关知识

为了完成本关任务,你需要掌握:

  1. python 向量的概念。
  2. Numpy 的使用方法。
python 向量的概念

向量被称为一维数组。

在数学建模中,向量是一个非常重要的知识,在处理数据集的时候,许多数据往往有多重属性,合理使用向量可以使数据集显示更加清晰。

Python 中处理数组的库叫做 Numpy ,Numpy 中包含了一些函数用于处理数组,大概可分为以下几类:

  • 修改数组形状
  • 翻转数组
  • 修改数组维度
  • 连接数组
  • 分割数组
  • 数组元素的添加与删除
修改数组形状
函数描述
reshape不改变数据的条件下修改形状
flat数组元素迭代器
flatten返回一份数组拷贝,对拷贝所做的修改不会影响原始数组
ravel返回展开数组
numpy.reshape

numpy.reshape 函数可以在不改变数据的条件下修改形状,格式如下:

numpy.reshape(arr, newshape, order='C')

  • arr:要修改形状的数组
  • newshape:整数或者整数数组,新的形状应当兼容原有形状
  • order:'C' -- 按行,'F' -- 按列,'A' -- 原顺序,'k' -- 元素在内存中的出现顺序。

实例

 
  1. a = np.arange(8)
  2. print ('原始数组:')
  3. print (a)
  4. print ('\n')
  5. b = a.reshape(4,2)
  6. print ('修改后的数组:')
  7. print (b)

输出结果如下:

 
  1. 原始数组:
  2. [0 1 2 3 4 5 6 7]
  3. 修改后的数组:
  4. [[0 1]
  5. [2 3]
  6. [4 5]
  7. [6 7]]
翻转数组
函数描述
transpose对换数组的维度
ndarray.T和 self.transpose() 相同
rollaxis向后滚动指定的轴
swapaxes对换数组的两个轴
numpy.transpose

numpy.transpose 函数用于对换数组的维度,格式如下:

numpy.transpose(arr, axes)

参数说明:

  • arr:要操作的数组
  • axes:整数列表,对应维度,通常所有维度都会对换。

实例

 
  1. a = np.arange(12).reshape(3,4)
  2. print ('原数组:')
  3. print (a )
  4. print ('\n')
  5. print ('对换数组:')
  6. print (np.transpose(a))

输出结果如下:

 
  1. 原数组:
  2. [[ 0 1 2 3]
  3. [ 4 5 6 7]
  4. [ 8 9 10 11]]
  5. 对换数组:
  6. [[ 0 4 8]
  7. [ 1 5 9]
  8. [ 2 6 10]
  9. [ 3 7 11]]
修改数组维度
维度描述
broadcast产生模仿广播的对象
broadcast_to将数组广播到新形状
expand_dims扩展数组的形状
squeeze从数组的形状中删除一维条目
numpy.broadcast

numpy.broadcast 用于模仿广播的对象,它返回一个对象,该对象封装了将一个数组广播到另一个数组的结果。

该函数使用两个数组作为输入参数,如下实例:

实例

 
  1. x = np.array([[1], [2], [3]])
  2. y = np.array([4, 5, 6])
  3. # 对 y 广播 x
  4. b = np.broadcast(x,y)
  5. # 它拥有 iterator 属性,基于自身组件的迭代器元组
  6. print ('对 y 广播 x:')
  7. r,c = b.iters
  8. # Python3.x 为 next(context) ,Python2.x 为 context.next()
  9. print (next(r), next(c))
  10. print (next(r), next(c))
  11. print ('\n')
  12. # shape 属性返回广播对象的形状
  13. print ('广播对象的形状:')
  14. print (b.shape)
  15. print ('\n')
  16. # 手动使用 broadcast 将 x 与 y 相加
  17. b = np.broadcast(x,y)
  18. c = np.empty(b.shape)
  19. print ('手动使用 broadcast 将 x 与 y 相加:')
  20. print (c.shape)
  21. print ('\n')
  22. c.flat = [u + v for (u,v) in b]
  23. print ('调用 flat 函数:')
  24. print (c)
  25. print ('\n')
  26. # 获得了和 NumPy 内建的广播支持相同的结果
  27. print ('x 与 y 的和:')
  28. print (x + y)

输出结果为:

 
  1. 对 y 广播 x:
  2. 1 4
  3. 1 5
  4. 广播对象的形状:
  5. (3, 3)
  6. 手动使用 broadcast 将 x 与 y 相加:
  7. (3, 3)
  8. 调用 flat 函数:
  9. [[5. 6. 7.]
  10. [6. 7. 8.]
  11. [7. 8. 9.]]
  12. x 与 y 的和:
  13. [[5 6 7]
  14. [6 7 8]
  15. [7 8 9]]
连接数组
函数描述
concatenate连接沿现有轴的数组序列
stack沿着新的轴加入一系列数组。
hstack水平堆叠序列中的数组(列方向)
vstack竖直堆叠序列中的数组(行方向)
numpy.concatenate

numpy.concatenate 函数用于沿指定轴连接相同形状的两个或多个数组,格式如下:

numpy.concatenate((a1, a2, ...), axis)

参数说明:

  • a1, a2, ...:相同类型的数组
  • axis:沿着它连接数组的轴,默认为 0

实例

 
  1. import numpy as np
  2. a = np.array([[1,2],[3,4]])
  3. print ('第一个数组:')
  4. print (a)
  5. print ('\n')
  6. b = np.array([[5,6],[7,8]])
  7. print ('第二个数组:')
  8. print (b)
  9. print ('\n')
  10. # 两个数组的维度相同
  11. print ('沿轴 0 连接两个数组:')
  12. print (np.concatenate((a,b)))
  13. print ('\n')
  14. print ('沿轴 1 连接两个数组:')
  15. print (np.concatenate((a,b),axis = 1))

输出结果为:

 
  1. 第一个数组:
  2. [[1 2]
  3. [3 4]]
  4. 第二个数组:
  5. [[5 6]
  6. [7 8]]
  7. 沿轴 0 连接两个数组:
  8. [[1 2]
  9. [3 4]
  10. [5 6]
  11. [7 8]]
  12. 沿轴 1 连接两个数组:
  13. [[1 2 5 6]
  14. [3 4 7 8]]
分割数组
函数数组及操作
split将一个数组分割为多个子数组
hsplit将一个数组水平分割为多个子数组(按列)
vsplit将一个数组垂直分割为多个子数组(按行)
numpy.split

numpy.split 函数沿特定的轴将数组分割为子数组,格式如下:

numpy.split(ary, indices_or_sections, axis) 参数说明:

  • ary:被分割的数组
  • indices_or_sections:如果是一个整数,就用该数平均切分,如果是一个数组,为沿轴切分的位置(左开右闭)
  • axis:设置沿着哪个方向进行切分,默认为 0,横向切分,即水平方向。为 1 时,纵向切分,即竖直方向。

实例

 
  1. import numpy as np
  2. a = np.arange(9)
  3. print ('第一个数组:')
  4. print (a)
  5. print ('\n')
  6. print ('将数组分为三个大小相等的子数组:')
  7. b = np.split(a,3)
  8. print (b)
  9. print ('\n')
  10. print ('将数组在一维数组中表明的位置分割:')
  11. b = np.split(a,[4,7])
  12. print (b)

输出结果为:

 
  1. 第一个数组:
  2. [0 1 2 3 4 5 6 7 8]
  3. 将数组分为三个大小相等的子数组:
  4. [array([0, 1, 2]), array([3, 4, 5]), array([6, 7, 8])]
  5. 将数组在一维数组中表明的位置分割:
  6. [array([0, 1, 2, 3]), array([4, 5, 6]), array([7, 8])]
数组元素的添加与删除
函数元素及描述
resize返回指定形状的新数组
append将值添加到数组末尾
insert沿指定轴将值插入到指定下标之前
delete删掉某个轴的子数组,并返回删除后的新数组
unique查找数组内的唯一元素
numpy.resize

numpy.resize 函数返回指定大小的新数组。

如果新数组大小大于原始大小,则包含原始数组中的元素的副本。

numpy.resize(arr, shape) 参数说明:

  • arr:要修改大小的数组
  • shape:返回数组的新形状

实例

 
  1. import numpy as np
  2. a = np.array([[1,2,3],[4,5,6]])
  3. print ('第一个数组:')
  4. print (a)
  5. print ('\n')
  6. print ('第一个数组的形状:')
  7. print (a.shape)
  8. print ('\n')
  9. b = np.resize(a, (3,2))
  10. print ('第二个数组:')
  11. print (b)
  12. print ('\n')
  13. print ('第二个数组的形状:')
  14. print (b.shape)
  15. print ('\n')
  16. # 要注意 a 的第一行在 b 中重复出现,因为尺寸变大了
  17. print ('修改第二个数组的大小:')
  18. b = np.resize(a,(3,3))
  19. print (b)

输出结果为:

 
  1. 第一个数组:
  2. [[1 2 3]
  3. [4 5 6]]
  4. 第一个数组的形状:
  5. (2, 3)
  6. 第二个数组:
  7. [[1 2]
  8. [3 4]
  9. [5 6]]
  10. 第二个数组的形状:
  11. (3, 2)
  12. 修改第二个数组的大小:
  13. [[1 2 3]
  14. [4 5 6]
  15. [1 2 3]]

编程要求

根据提示在右侧代码器中 Begin-End 区间补充代码,做到将数组 a1 和 a2 分别沿轴0和轴 1 连接。

测试说明

平台会对你编写的代码进行测试:

import numpy as np

a = np.array([[1,2],[3,4]])
b = np.array([[5,6],[7,8]])

print('第一个数组:')
print(a)
print('\n')

print('第二个数组:')
print(b)
print('\n')

# 两个数组的维度相同

print('沿轴 0 连接两个数组:')
########## begin ##########
result_axis0 = np.concatenate((a, b), axis=0)
print(result_axis0)
##########  end  ##########
print('\n')

print('沿轴 1 连接两个数组:')
########## begin ##########
result_axis1 = np.concatenate((a, b), axis=1)
print(result_axis1)
##########  end  ##########

第5关:函数

  • 任务描述
  • 相关知识
    • Python 函数
    • 定义一个函数
    • 函数调用
    • 参数传递
    • 参数
    • 匿名函数
    • return 语句
    • 变量作用域
    • 全局变量和局部变量
  • 编程要求
  • 测试说明

任务描述

本关任务:学习 Python 中的函数,掌握建模一大利器。

相关知识

为了完成本关任务,你需要掌握:

  1. 定义一个函数。
  2. 函数调用。
  3. 参数传递。
  4. 参数。
  5. 匿名函数。
  6. return 语句。
  7. 变量作用域。
  8. 全局变量和局部变量。
Python 函数

函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。

函数能提高应用的模块性,和代码的重复利用率。你已经知道 Python 提供了许多内建函数,比如 print()。但你也可以自己创建函数,这被叫做用户自定义函数。

图  1


函数

定义一个函数

你可以定义一个由自己想要功能的函数,以下是简单的规则:

  • 函数代码块以 def 关键词开头,后接函数标识符名称和圆括号()。

  • 任何传入参数和自变量必须放在圆括号中间。圆括号之间可以用于定义参数。

  • 函数的第一行语句可以选择性地使用文档字符串—用于存放函数说明。

  • 函数内容以冒号起始,并且缩进。

  • return [表达式] 结束函数,选择性地返回一个值给调用方。不带表达式的 return 相当于返回 None。

语法

 
  1. def functionname( parameters ):
  2. "函数_文档字符串"
  3. function_suite
  4. return [expression]

默认情况下,参数值和参数名称是按函数声明中定义的顺序匹配起来的。

实例

以下为一个简单的Python函数,它将一个字符串作为传入参数,再打印到标准显示设备上。

 
  1. def printme( str ):
  2. "打印传入的字符串到标准显示设备上"
  3. print str
  4. return
函数调用

定义一个函数只给了函数一个名称,指定了函数里包含的参数,和代码块结构。

这个函数的基本结构完成以后,你可以通过另一个函数调用执行,也可以直接从 Python 提示符执行。

如下实例调用了 printme()函数:

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. # 定义函数
  4. def printme( str ):
  5. "打印任何传入的字符串"
  6. print str
  7. return
  8. # 调用函数
  9. printme("我要调用用户自定义函数!")
  10. printme("再次调用同一函数")

以上实例输出结果:

 
  1. 我要调用用户自定义函数!
  2. 再次调用同一函数
参数传递

在 python 中,类型属于对象,变量是没有类型的:

 
  1. a=[1,2,3]
  2. a="Runoob"

以上代码中,[1,2,3] 是 List 类型,"Runoob" 是 String 类型,而变量 a 是没有类型,她仅仅是一个对象的引用(一个指针),可以是 List 类型对象,也可以指向 String 类型对象。

可更改 ( mutable ) 与不可更改 ( immutable ) 对象

在 python 中,strings, tuples, 和 numbers 是不可更改的对象,而 list,dict 等则是可以修改的对象。

  • 不可变类型:变量赋值 a=5 后再赋值 a=10,这里实际是新生成一个 int 值对象 10,再让 a 指向它,而 5 被丢弃,不是改变a的值,相当于新生成了 a 。

  • 可变类型:变量赋值 la=[1,2,3,4] 后再赋值 la[2]=5 则是将 list la 的第三个元素值更改,本身 la 没有动,只是其内部的一部分值被修改了。

python 函数的参数传递:

  • 不可变类型:类似 c++ 的值传递,如 整数、字符串、元组。如 fun(a),传递的只是a的值,没有影响 a 对象本身。比如在 fun(a)内部修改 a 的值,只是修改另一个复制的对象,不会影响 a 本身。

  • 可变类型:类似 c++ 的引用传递,如 列表,字典。如 fun(la),则是将 la 真正的传过去,修改后 fun 外部的 la 也会受影响。

python 中一切都是对象,严格意义我们不能说值传递还是引用传递,我们应该说传不可变对象和传可变对象。

python 传不可变对象实例

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. def ChangeInt( a ):
  4. a = 10
  5. b = 2
  6. ChangeInt(b)
  7. print b # 结果是 2

实例中有 int 对象 2,指向它的变量是 b,在传递给 ChangeInt 函数时,按传值的方式复制了变量 b,a 和 b 都指向了同一个 Int 对象,在 a=10 时,则新生成一个 int 值对象 10,并让 a 指向它。

传可变对象实例

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. # 可写函数说明
  4. def changeme( mylist ):
  5. "修改传入的列表"
  6. mylist.append([1,2,3,4])
  7. print "函数内取值: ", mylist
  8. return
  9. # 调用changeme函数
  10. mylist = [10,20,30]
  11. changeme( mylist )
  12. print "函数外取值: ", mylist

实例中传入函数的和在末尾添加新内容的对象用的是同一个引用,故输出结果如下:

 
  1. 函数内取值: [10, 20, 30, [1, 2, 3, 4]]
  2. 函数外取值: [10, 20, 30, [1, 2, 3, 4]]
参数

以下是调用函数时可使用的正式参数类型:

  • 必备参数
  • 关键字参数
  • 默认参数
  • 不定长参数

必备参数

必备参数须以正确的顺序传入函数。调用时的数量必须和声明时的一样。

调用 printme() 函数,你必须传入一个参数,不然会出现语法错误:

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. #可写函数说明
  4. def printme( str ):
  5. "打印任何传入的字符串"
  6. print str
  7. return
  8. #调用printme函数
  9. printme()

以上实例输出结果:

 
  1. Traceback (most recent call last):
  2. File "test.py", line 11, in <module>
  3. printme()
  4. TypeError: printme() takes exactly 1 argument (0 given)

关键字参数

关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。

使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为 Python 解释器能够用参数名匹配参数值。

以下实例在函数 printme() 调用时使用参数名:

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. #可写函数说明
  4. def printme( str ):
  5. "打印任何传入的字符串"
  6. print str
  7. return
  8. #调用printme函数
  9. printme( str = "My string")

以上实例输出结果:

 
  1. My string

下例能将关键字参数顺序不重要展示得更清楚:

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. #可写函数说明
  4. def printinfo( name, age ):
  5. "打印任何传入的字符串"
  6. print "Name: ", name
  7. print "Age ", age
  8. return
  9. #调用printinfo函数
  10. printinfo( age=50, name="miki" )

以上实例输出结果:

 
  1. Name: miki
  2. Age 50

默认参数 调用函数时,默认参数的值如果没有传入,则被认为是默认值。下例会打印默认的 age ,如果 age 没有被传入:

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. #可写函数说明
  4. def printinfo( name, age = 35 ):
  5. "打印任何传入的字符串"
  6. print "Name: ", name
  7. print "Age ", age
  8. return
  9. #调用printinfo函数
  10. printinfo( age=50, name="miki" )
  11. printinfo( name="miki" )

以上实例输出结果:

 
  1. Name: miki
  2. Age 50
  3. Name: miki
  4. Age 35

不定长参数 你可能需要一个函数能处理比当初声明时更多的参数。这些参数叫做不定长参数,和上述 2 种参数不同,声明时不会命名。基本语法如下:

 
  1. def functionname([formal_args,] *var_args_tuple ):
  2. "函数_文档字符串"
  3. function_suite
  4. return [expression]

加了星号的变量名会存放所有未命名的变量参数。不定长参数实例如下:

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. # 可写函数说明
  4. def printinfo( arg1, *vartuple ):
  5. "打印任何传入的参数"
  6. print "输出: "
  7. print arg1
  8. for var in vartuple:
  9. print var
  10. return
  11. # 调用printinfo 函数
  12. printinfo( 10 )
  13. printinfo( 70, 60, 50 )

以上实例输出结果:

 
  1. 输出:
  2. 10
  3. 输出:
  4. 70
  5. 60
  6. 50
匿名函数

python 使用 lambda 来创建匿名函数。

  • lambda 只是一个表达式,函数体比 def 简单很多。

  • lambda 的主体是一个表达式,而不是一个代码块。仅仅能在 lambda 表达式中封装有限的逻辑进去。

  • lambda 函数拥有自己的命名空间,且不能访问自有参数列表之外或全局命名空间里的参数。

  • 虽然lambda函数看起来只能写一行,却不等同于 C 或 C++ 的内联函数,后者的目的是调用小函数时不占用栈内存从而增加运行效率。

语法

lambda 函数的语法只包含一个语句,如下:

lambda [arg1 [,arg2,.....argn]]:expression 如下实例:

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. # 可写函数说明
  4. sum = lambda arg1, arg2: arg1 + arg2
  5. # 调用sum函数
  6. print "相加后的值为 : ", sum( 10, 20 )
  7. print "相加后的值为 : ", sum( 20, 20 )

以上实例输出结果:

 
  1. 相加后的值为 : 30
  2. 相加后的值为 : 40
return 语句

return 语句[表达式]退出函数,选择性地向调用方返回一个表达式。不带参数值的 return 语句返回 None 。之前的例子都没有示范如何返回数值,下例便告诉你怎么做:

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. # 可写函数说明
  4. def sum( arg1, arg2 ):
  5. # 返回2个参数的和."
  6. total = arg1 + arg2
  7. print "函数内 : ", total
  8. return total
  9. # 调用sum函数
  10. total = sum( 10, 20 )

以上实例输出结果:

 
  1. 函数内 : 30
变量作用域

一个程序的所有的变量并不是在哪个位置都可以访问的。访问权限决定于这个变量是在哪里赋值的。

变量的作用域决定了在哪一部分程序你可以访问哪个特定的变量名称。两种最基本的变量作用域如下:

  • 全局变量

  • 局部变量

全局变量和局部变量

定义在函数内部的变量拥有一个局部作用域,定义在函数外的拥有全局作用域。

局部变量只能在其被声明的函数内部访问,而全局变量可以在整个程序范围内访问。调用函数时,所有在函数内声明的变量名称都将被加入到作用域中。如下实例:

 
  1. #!/usr/bin/python
  2. # -*- coding: UTF-8 -*-
  3. total = 0 # 这是一个全局变量
  4. # 可写函数说明
  5. def sum( arg1, arg2 ):
  6. #返回2个参数的和."
  7. total = arg1 + arg2 # total在这里是局部变量.
  8. print "函数内是局部变量 : ", total
  9. return total
  10. #调用sum函数
  11. sum( 10, 20 )
  12. print "函数外是全局变量 : ", total

以上实例输出结果:

 
  1. 函数内是局部变量 : 30
  2. 函数外是全局变量 : 0

编程要求

根据提示在右侧代码器中 Begin-End 区间补充代码,求学生最高分数科目和分数。

测试说明

平台会对你编写的代码进行测试:

def get_max_score(score_dic):
    """
    返回学生考试成绩的最高分的科目和分数
    :param score_dic:
    :return:
    """
    max_score = 0
    max_score_course = ''
    for course, score in score_dic.items():
        ########## begin ##########
        if score > max_score:
        ##########  end  ##########
            max_score = score
            max_score_course = course
    ########## begin ##########
    return max_score_course, max_score
    ##########  end  ##########

dic = {
    '语文': 90,
    '数学': 97,
    '英语': 98
}

course, score = get_max_score(dic)
print(course, score)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/234699.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【数据挖掘】国科大苏桂平老师数据库新技术课程作业 —— 第四次作业

云数据库研究 云计算与云数据库背景 云计算&#xff08;cloud computing&#xff09;是 IT 技术发展的最新趋势&#xff0c;正受到业界和学术界的广泛关注。云计算是在分布式处理、并行处理和网格计算等技术的基础上发展起来的&#xff0c;是一种新兴的共享基础架构的方法。它…

大数据技术7:基于StarRocks统一OALP实时数仓

前言&#xff1a; 大家对StarRocks 的了解可能不及 ClickHouse或者是远不及 ClickHouse 。但是大家可能听说过 Doris &#xff0c;而 StarRocks 实际上原名叫做 Doris DB &#xff0c;他相当于是一个加强版的也就是一个 Doris ,也就是说 Doris 所有的功能 StarRocks 都是有的&a…

this.$emit(‘update:isVisible‘, false)作用

这个写是不是很新颖&#xff0c;传父组件传值&#xff01;这是什么鬼。。。 假设你有以下逻辑业务。在A页面弹出一个组件B&#xff0c;A组件里面使用B组件&#xff0c;是否展示B组件你使用的是baselineShow变量控制&#xff01; <BaselineData :isVisible.sync"basel…

SQL命令---修改字段的排列位置

介绍 使用sql语句表字段的排列顺序。 命令 alter table 表名 modify 字段名1 数据类型 first|after 字段名2;例子 将a表中的age字段改为表的第一个字段。 alter table a modify age int(12) first;下面是执行命令后的表结构&#xff1a; 将a表中的age字段放到name字段之…

ELK简单介绍二

学习目标 能够部署kibana并连接elasticsearch集群能够通过kibana查看elasticsearch索引信息知道用filebeat收集日志相对于logstash的优点能够安装filebeat能够使用filebeat收集日志并传输给logstash kibana kibana介绍 Kibana是一个开源的可视化平台,可以为ElasticSearch集群…

linux 15day apache apache服务安装 httpd服务器 安装虚拟主机系统 一个主机 多个域名如何绑定

目录 一、apache安装二、访问控制总结修改默认网站发布目录 三、虚拟主机 一、apache安装 [rootqfedu.com ~]# systemctl stop firewalld [rootqfedu.com ~]# systemctl disable firewalld [rootqfedu.com ~]# setenforce 0 [rootqfedu.com ~]# yum install -y httpd [rootqfe…

用23种设计模式打造一个cocos creator的游戏框架----(十二)状态模式

1、模式标准 模式名称&#xff1a;状态模式 模式分类&#xff1a;行为型 模式意图&#xff1a;允许一个对象在其内部状态改变时改变它的行为。对象看起来似乎修改了它的类。 结构图&#xff1a; 适用于&#xff1a; 1、一个对象的行为决定于它的状态&#xff0c;并且它必须…

记录一次云原生线上服务数据迁移全过程

文章目录 背景迁移方案调研迁移过程服务监控脚本定时任务暂停本地副本服务启动&#xff0c;在线服务下线MySQL 数据迁移Mongo 数据迁移切换新数据库 ip 本地服务启动数据库连接验证服务打包部署服务重启前端恢复正常监控脚本定时任务启动旧服务器器容器关闭 迁移总结 背景 校园…

代码随想录二刷 |二叉树 |101. 对称二叉树

代码随想录二刷 &#xff5c;二叉树 &#xff5c;101. 对称二叉树 题目描述解题思路 & 代码实现递归法迭代法使用队列使用栈 题目描述 101.对称二叉树 给你一个二叉树的根节点 root &#xff0c; 检查它是否轴对称。 示例 1&#xff1a; 输入&#xff1a;root [1,2,2,…

adb unauthorized 踩坑记录

给Realme X7 Pro 安装Root后&#xff0c;发现adb连接设备呈现unauthorized 状态&#xff1a; 在Google以后&#xff0c;尝试了很多方案&#xff0c;均无效&#xff0c;尝试的方案如下&#xff1a; 重启手机&#xff0c;电脑。不行撤销调试授权&#xff0c;开关usb调试&#xf…

持续集成交付CICD:Jenkins配置Nexus制品发布

目录 一、实验 1.Jenkins配置Nexus制品发布 一、实验 1.Jenkins配置Nexus制品发布 &#xff08;1&#xff09;策略 发布其实就是下载制品&#xff0c;然后将制品发送到目标主机&#xff0c;最后通过脚本或者指令启动程序。 &#xff08;2&#xff09;安装Maven Artifact …

基于JavaWeb+SSM+Vue马拉松报名系统微信小程序的设计和实现

基于JavaWebSSMVue马拉松报名系统微信小程序的设计和实现 源码获取入口Lun文目录前言主要技术系统设计功能截图订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码获取入口 Lun文目录 1系统概述 1 1.1 研究背景 1 1.2研究目的 1 1.3系统设计思想 1 2相关技术 2 2.…

SQL命令---添加新字段

介绍 使用sql语句为表添加新字段。 命令 alter table 表名 add 新字段名 数据类型;例子 向a表中添加name字段&#xff0c;类型为varchar(255)。 alter table a add name varchar(255);下面是执行添加有的表结构&#xff1a;

react之项目打包,本地预览,路由懒加载,打包体积分析以及如何配置CDN

react之项目打包,本地预览,路由懒加载,打包体积分析以及如何配置CDN 一、项目打包二、项目本地预览三、路由懒加载四、打包体积分析五、配置CDN 一、项目打包 执行命令 npm run build根目录下生成的build文件夹 及时打包后的文件 二、项目本地预览 1.全局安装本地服务包 npm…

内存分配器

实现分配器需要考虑的问题 空闲块的组织方式&#xff1a;如何记录现有的空闲块空闲块的选择&#xff1a;如何选择一个合适的空闲块空闲块的分割&#xff1a;选择了一个合适的空闲块后如何处理空闲块内部的剩余部分空闲块的合并&#xff1a;如何处理一个刚刚被释放的块&#xf…

Python sqlalchemy使用

基本结构 #!/usr/bin/python3 # -*- coding:utf-8 -*- """ author: JHC file: base_db.py time: 2023/6/19 21:34 desc: """ from sqlalchemy import create_engine,text from sqlalchemy.orm import sessionmaker,scoped_session from contex…

计算机服务器中了Mallox勒索病毒怎么解密,Mallox勒索病毒解密步骤

计算机网络技术的不断发展与应用&#xff0c;为企业的生产运营提供了坚实的基础&#xff0c;大大提高了企业的生产与工作效率&#xff0c;但随之而来的网络安全威胁也在不断增加。在本月&#xff0c;云天数据恢复中心接到了很多企业的求助&#xff0c;企业的计算机服务器遭到了…

Nacos源码解读12——Nacos中长连接的实现

短连接 VS 长连接 什么是短连接 客户端和服务器每进行一次HTTP操作&#xff0c;就建立一次连接&#xff0c;任务结束就中断连接。 长连接 客户端和服务器之间用于传输HTTP数据的TCP连接不会关闭&#xff0c;客户端再次访问这个服务器时&#xff0c;会继续使用这一条已经建立…

数理统计基础:参数估计与假设检验

在学习机器学习的过程中&#xff0c;我充分感受到概率与统计知识的重要性&#xff0c;熟悉相关概念思想对理解各种人工智能算法非常有意义&#xff0c;从而做到知其所以然。因此打算写这篇笔记&#xff0c;先好好梳理一下参数估计与假设检验的相关内容。 1 总体梳理 先从整体结…

【Spring 基础】00 入门指南

【Spring 基础】00 入门指南 文章目录 【Spring 基础】00 入门指南1.简介2.概念1&#xff09;控制反转&#xff08;IoC&#xff09;2&#xff09;依赖注入&#xff08;DI&#xff09; 3.核心模块1&#xff09;Spring Core2&#xff09;Spring AOP3&#xff09;Spring MVC4&…