先上代码:
from functools import reduce
print(sum(list(map(lambda k:reduce(lambda x,y:y*x ,[i for i in range(1,k+1)]),[i for i in range(1,int(input())+1)]))))
再上一个简化之后的代码,大家可以自己领悟:
from functools import reduce
print(sum(list(reduce(lambda x,y:x*y,range(1,i+1))for i in range(1,int(input())+1))))
接下来就是分解了:
第一步 求阶乘:
reduce(lambda x,y:y*x ,[i for i in range(1,k+1)])
补充说明1:lambda 匿名函数,所谓匿名,就是一个没有名字的函数,只知道功能,不知其名。
其用法 lambda 参数1,参数2,.. ,参数n: 函数体
例如:
补充说明2:reduce 函数 ,知道map reduce 的应该有了解,在这里引入一个论述:
reduce(function, sequence[, initial]) -> value
Apply a function of two arguments cumulatively to the items of a sequence,
from left to right, so as to reduce the sequence to a single value.
For example, reduce(lambda x, y: x+y, [1, 2, 3, 4, 5]) calculates
((((1+2)+3)+4)+5). If initial is present, it is placed before the items
of the sequence in the calculation, and serves as a default when the
sequence is empty.
换成人话就是:意思就是对sequence连续使用function, 如果不给出initial, 则第一次调用传递sequence的两个元素, 以后把前一次调用的结果和sequence的下一个元素传递给function. 如果给出initial, 则第一次传递initial和sequence的第一个元素给function.
比如:
分析 其运算过程 第一步:x=1,y=2 返回1*2,因为没给出initia,取其两个数;第二步:此时x=3,y=1*2=2,没错就是上一次运算的结果,返回2*3=6;第三步x=4,y=6,又没错,是上一次运算的结果 ,返回4*6=24;第四步:x=5,y=24,返回5*24=120。
第二步得到阶乘列表:
list(map(lambda k:reduce(lambda x,y:y*x ,[i for i in range(1,k+1)]),[i for i in range(1,int(input())+1)]))
补充说明 map 函数:
map 函数用法 map(函数,参数1,参数2,...,参数n),在python 3中 返回map类型的序列,python2中返回列表
例如:
并行计算,1+4,2+5,3+6 一一对应。
通过第一步 我们得到求阶乘的公式,reduce(lambda x,y:y*x ,[i for i in range(1,k+1)]),通过lambda 包装一下,就成了一个函数,lambda k:reduce(lambda x,y:y*x ,[i for i in range(1,k+1)]) ,对 我们要求的阶乘 的数的列表 [i for i in range(1,int(input())+1)](因为input函数输入的是字符,要用int函数转换成整型,range(start,end,sequence)函数只取start,和end-1,因此需要加一),map一下即可得到对应的阶乘数序列,因为python3返回map序列,我们需要list函数转换一下。
第三步求阶乘和:
python有内置函数sum可以求列表中元素的和,当然你也可以试试reduce和lambda函数结合,就像求阶乘一样。
sum(list(map(lambda k:reduce(lambda x,y:y*x ,[i for i in range(1,k+1)]),[i for i in range(1,int(input())+1)])))
最后print一下就好了,欢迎大家批评指正!学习心得分享一下,因为在做牛客,想用最简洁的代码做题目。