题目链接:https://www.educoder.net/tasks/py2izujr935h
第1关:递归函数 - 汉诺塔的魅力
#coding=utf-8
# 输入正整数n
n = int(input())
# 请在此添加代码,对输入的正整数n进行阶乘运算,并输出计算结果。
#********** Begin *********#
def fact(n):
count=1
for x in range(1,n+1):
count*=x
return count
print(fact(n))
#********** End **********#
第2关:Lambda函数 - 匿名函数的使用
#coding=utf-8
# 请在此添加代码,使用lambda来创建匿名函数,能够判断输入的两个数值的大小,
#********** Begin *********#
MAXIMUM = lambda x,y:max(x,y)
MINIMUM = lambda x,y:min(x,y)
#********** End **********#
# 输入两个正整数
a = int(input())
b = int(input())
# 输出较大的值和较小的值
print('较大的值是:%d' % MAXIMUM(a,b))
print('较小的值是:%d' % MINIMUM(a,b))
第3关:Map-Reduce - 映射与归约的思想
#coding=utf-8
# 输入一个正整数
x = int(input())
n = x
# 请在此添加代码,将输入的一个正整数分解质因数
#********** Begin *********#
result=[]
for i in range(2,x):
while x != i:
if(x%i==0):
result.append(i)
x=x/i
else:
break
result.append(int(x))
#********** End **********#
# 输出结果,利用map()函数将结果按照规定字符串格式输出
print(n,'=','*'.join(map(str,result)))