|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
要求写一个阶乘的函数,
原版非递归代码如下:
def recursion(n):
result = n
for i in range(1,n)
result *= i
return result
number = int(input("请输入一个整数:"))
result = recursion(number)
print("%d的阶乘是:%d" %(nubmer,result))
这样子运行没问题,这段代码我只是不明白那个n。另外,我想升级一下,要求如下:求某个区间内的阶乘,比如求从5到10的阶乘,即:5X6X7X8X9X10。
在上面代码基础上,我修改如下:
def recursion(n):
result = n
for i in range(n1,n2)
result *= i
return result
n1 = int(input("请输入起始整数:"))
n2 = int(input("请输入终止整数:"))
result = recursion(n1,n2)
print("起始数为%d,终止数为%d的阶乘是:%d" %(n1,n2,result))
我想知道,怎样改(不用递归)更合理。我是纯新手小白,请尽量用通俗的语言解释。谢谢!
本帖最后由 qiuyouzhi 于 2020-2-21 16:13 编辑
- def recursion(n1, n2):
- result = n2
- for i in range(n1,n2):
- result *= i
- return result
- n1 = int(input("请输入起始整数:"))
- n2 = int(input("请输入终止整数:"))
- result = recursion(n1,n2)
复制代码
试试
|
|