nynw.net
当前位置:首页 >> 如何用Python循环语句制作n的阶乘 >>

如何用Python循环语句制作n的阶乘

from functools import reducefrom operator import muldef jiecheng(n): return reduce(mul, range(1, n+1)) if __name__ == '__main__': for i in range(3, 10): print('{}! = {}'.format(i, jiecheng(i)))wenjie@digi007:~/study/zhidao$ pyt...

def jieshen(n): sum = 1 while sum

def fact(n):if n==0:return 1else:return n*fact(n-1)n=int(input())print(fact(n))

可以用循环loop或递归来(recursion)来解决类似问题 应用loop: def factorial_loop(n): res = 1 for i in range((1,n+1): res *= i return res print factorial(15) 2. recursion def factorial_recursion(n): if n >> 1307674368000 此外还可...

阶乘有一个经典的递归调用算法。以下是示例代码。 def jiecheng(n): if n==1 or n==0: return 1 return n*jiecheng(n-1)print('5的阶乘为%s'%jiecheng(5))

def factorial(n): if n == 1: return 1 else: return n * factorial(n - 1)input_num = input()try: with open('jc.txt', 'w') as file: file.write(str(factorial(int(input_num))))except IOError as e: print('error', e)

# 普通遍历def f1(n): r = 1 while n > 1: r *= n n -= 1 return r# 递归def f2(n): if n == 1: return 1 else: return n * f2(n - 1)if __name__ == '__main__': print(f1(6)) print(f2(6))

def jiecheng(n=10): temp = 1 for i in range(n): temp = temp * (n+1) return temp

def jiezheng(n): if n==1 or n==0: return 1 return n*jiezheng(n-1)递归调用函数jiezheng算阶乘 jiezheng(5) 返回120

前两个都封装成了函数。最后一个直接运行的。没有定义函数。 中间那个问题,是因为你忘记做类型转换,你试着运行这个number=int(number)。应该 就对了。

网站首页 | 网站地图
All rights reserved Powered by www.nynw.net
copyright ©right 2010-2021。
内容来自网络,如有侵犯请联系客服。zhit325@qq.com