蒜术师给了一个正整数 n,让你求出不大于 n 的正整数的阶乘的和(即求 1!+2!+3!+...+n!1!+2!+3!+...+n!)。

输入格式

输入有一行,包含一个正整数 n(1 < n < 12)

输出格式

输出一个整数,表示阶乘的和。

样例输入:

5

样例输出:

153

def fac(m):
    while m>=0:
        if m==0:
            return 1
        else:
            return (m*fac(m-1))
n=int(input())
s=0
for i in range(1,n+1):
    s +=fac(i)
print(s)

这道题我所给代码同时可以解决求阶乘问题,采用先定义一个函数来进行计算,不会在后续输入中感觉到复杂,易理解,看起来也十分明朗。这道题我先计算阶乘再计算阶乘和也是为了看起来更清楚一些,计算时也不会感觉到糊涂,在遇到类似问题时,先定义函数会让你更清楚的看出错误,所以我建议大家也可以这样做题。