函数使用进阶作业参考答案
练习1:在一个模块中编写一个判断一个数是不是完美数的函数,在另一个模块中调用该函数找出10000以内的所有完美数。
说明:一个正整数所有的真因子(即除了自身以外的因子)的和,恰好等于它本身,那么这个数就是“完美数”。例如:6是完美数,因为
6 = 1 + 2 +3
;28是完美数,因为28 = 1 + 2 + 4 + 7 + 14
。
"""
homework01.py
"""
def is_perfect(num):
total = 1
for factor in range(2, int(num ** 0.5) + 1):
if num % factor == 0:
total += factor
factor2 = num // factor
if factor != factor2:
total += factor2
return total == num
"""
homework02.py
"""
for num in range(1, 10000):
if is_perfect(num):
print(num)
练习2:写一个函数,实现对传入的多个参数中的数值元素求中位数的操作。
说明:中位数(Median)又称中值,统计学中的专有名词,是按顺序排列的一组数据中居于中间位置的数,对于有限的数集,可以通过把所有观察值高低排序后找出正中间的一个作为中位数。 如果观察值有偶数个,通常取最中间的两个数值的平均数作为中位数。
def find_median(*args):
nums = [arg for arg in args if type(arg) in (int, float)]
nums_len, mid = len(nums), len(nums) // 2
nums.sort()
if nums_len % 2:
return nums[mid]
else:
return (nums[mid - 1] + nums[mid]) / 2
练习3:写一个函数,实现对传入的整数进行质因子分解的操作,返回所有质因子的列表。
def list_prime_factors(num):
factors, factor = [], 2
while num > 1:
if num % factor == 0:
factors.append(factor)
num //= factor
else:
factor += 1
return factors
练习4:一个小孩爬楼梯,每次可以爬1个、2个或3个台阶,编程求出这个小孩爬完10个台阶的楼梯一共有多少种走法。
from functools import lru_cache
@lru_cache()
def climb(num):
if num == 0:
return 1
if num < 0:
return 0
return climb(num - 1) + climb(num - 2) + climb(num - 3)
print(climb(10))
练习5:写一个装饰器,实现将被装饰函数返回的字符串每个单词首字母大写的功能。
from functools import wraps
def render_to_title(func):
@wraps(func)
def wrapper(*args, **kwargs):
result = func(*args, **kwargs)
if type(result) == str:
result = result.title()
return result
return wrapper