FIsh论坛《零基础入门学习Python》| 第017讲:函数 - Python的乐高积木
测试题
1.你有听说过DRY吗?
DRY是程序员们公认的指导原则:Don’t Repeat Yourself.
2.都是重复一段代码,为什么我要使用函数(而不使用简单的拷贝黏贴)呢?
使用函数
0) 可以降低代码量(调用函数只需要一行,而拷贝黏贴需要N倍代码)
1) 可以降低维护成本(函数只需修改def部分内容,而拷贝黏贴则需要每一处出现的地方都作修改)
2) 使序更容易阅读(没有人会希望看到一个程序重复一万行“I love FishC.com”)
3.函数可以有多个参数吗?
可以
4.创建函数使用什么关键字,要注意什么?
使用“def”关键字,要注意函数名后边要加上小括号“()”,小括号后边是冒号“:”,缩进部分均属于函数体的内容,例如:
def MyFun():
# 我是函数体
# 我也是函数体
# 我们都属于函数MyFun()
# 噢,我不属于MyFun()函数的了
5.请问这个函数有多少个参数?
def MyFun((x, y), (a, b)):
return x * y - a * b
答案是0,类似于这样的写法是错误的!
函数的参数需要的是变量,而这里试图用“元组”的形式来传递是不可行的。
修改后的代码:
def MyFun(x, y):
return x[0] * x[1] - y[0] * y[1]
print(MyFun((3, 4), (1, 2)))
输出结果:
10
6.请问调用以下这个函数会打印什么内容?
def hello():
print('Hello World!')
return
print('Welcome To FishC.com!')
print(hello())
输出结果:
Hello World!
None
当Python执行到return语句的时候,Python认为函数到此结束,需要返回了(尽管没有任何返回值)。
动动手:
1.编写一个函数power()模拟内建函数pow(),即power(x, y)为计算并返回x的y次幂的值。
Python3 pow() 函数
pow() 方法返回 xy(x的y次方) 的值。
import math
math.pow( x, y )
import math # 导入 math 模块
print ("math.pow(100, 2) : ", math.pow(100, 2))
# 使用内置,查看输出结果区别
print ("pow(100, 2) : ", pow(100, 2))
print ("math.pow(100, -2) : ", math.pow(100, -2))
print ("math.pow(2, 4) : ", math.pow(2, 4))
print ("math.pow(3, 0) : ", math.pow(3, 0))
输出结果:
math.pow(100, 2) : 10000.0
pow(100, 2) : 10000
math.pow(100, -2) : 0.0001
math.pow(2, 4) : 16.0
math.pow(3, 0) : 1.0
2.编写一个函数,利用欧几里得算法(脑补链接)求最大公约数,例如gcd(x, y)返回值为参数x和参数y的最大公约数。
欧几里德算法又称辗转相除法,用于计算两个整数a,b的最大公约数。
实例:
假如需要求 1997 和 615 两个正整数的最大公约数,用欧几里得算法,是这样进行的:
1997 / 615 = 3 (余 152)
615 / 152 = 4(余7)
152 / 7 = 21(余5)
7 / 5 = 1 (余2)
5 / 2 = 2 (余1)
2 / 1 = 2 (余0)
至此,最大公约数为1
以除数和余数反复做除法运算,当余数为 0 时,取当前算式除数为最大公约数,所以就得出了 1997 和 615 的最大公约数 1。参考代码:
def gcd(a, b):
while a != 0:
a, b = b % a, a
return b
def gcd(x, y):
while y:
t = x % y
x = y
y = t
return x
print(gcd(4, 6))
print(gcd(1997, 615))
print(gcd(615, 1997))
输出结果:
2
1
1
3.编写一个将十进制转换为二进制的函数,要求采用“除2取余”(脑补链接)的方式,结果与调用bin()一样返回字符串形式。
Python bin() 函数
bin() 返回一个整数 int 或者长整数 long int 的二进制表示。
语法:
bin(x)
参数:x – int 或者 long int 数字
返回值:字符串。
print(bin(10))
print(bin(20))
输出结果:
0b1010
0b10100
参考代码:
def Dec2Bin(dec):
temp = []
result = ''
while dec:
quo = dec % 2
dec = dec // 2 #地板除法
temp.append(quo)
while temp:
result += str(temp.pop())
return result
print(Dec2Bin(62))
print(Dec2Bin(10))
输出结果:
111110
1010
4.请写下这一节课你学习到的内容:格式不限,回忆并复述是加强记忆的好方式!
DRY原则、欧几里德算法