# 普通遍历
创新互联建站自2013年创立以来,是专业互联网技术服务公司,拥有项目网站设计、成都网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元宽城做网站,已为上家服务,为宽城各地企业和个人服务,联系电话:18980820575
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):
result = 1
for i in range(1,n+1):
result = result*i
return result
有阶乘函数:
improt numpy
print numpy.math.factorial(3)
python 自带的标准库也有阶乘函数
import math
print math.factorial(3)
解法1
数组解法牛。
首先定义一个ns数组用来存储n!的各个位数上的数值,利用for循环给ns加入10000个0值,以方便后面直接根据index对数组进行操作。
然后定义length作为 “数组的长度”(有真实数值的而非自动添加的0) 也即n!的结果的位数。
之后也必须用到for循环进行累乘,但跟解法一的直接累乘不同,这里是乘数(即i)跟各个位上的数分别相乘,若结果大于等于10则carry0即向前进一位数值为carry,若j循环结束后carry0则说明需要在当前ns的“长度”上进一位,所以length+1即位数+1,这里carry起的就是判断是否进位的作用,而length则代表着结果的位数。
n= int(input())
ns = [0 for i in range(10000) ]
n= int(input())
ns = [0 for i in range(10000) ]
length = 1
ns[0] = length = 1
if n=2:
#for i in range(2,n+1):
##carry = 0
##for j in range(length):
###temp = ns[j] * i + carry
###carry = int(temp/10)
###ns[j] = temp % 10
##while carry0:
###ns[length] += carry%10
###length+=1
###carry = int(carry/10)
while length0:
#length -=1
#print(ns[length],end='')
把# 替换为空格就可以运行。
如输入1000,计算1000!
解法2
print()
m=int(input("计算m!,请输入整数m:"))
import math
a=sum([math.log10(i) for i in range(1,m+1)])
b=int(a)
c=a-b
print(f'{m}!={10**c}*10^{b}')
1 math.factorial(x)
用python计算n的阶乘的方法!(含示例代码)
2. reduce函数
用python计算n的阶乘的方法!(含示例代码)
3. 递归实现
如果你想在 Python 中通过函数求出 s=a!+b!+c!,你可以使用递归函数来实现。
首先,你需要定义一个函数来计算阶乘,代码如下:
def factorial(n):
if n == 1:
return 1
else:
return n * factorial(n - 1)
这个函数使用了递归的思想,在 n 等于 1 时返回 1,否则返回 n * (n-1)!。
然后,你可以定义另一个函数来计算 s=a!+b!+c!,代码如下:
def sum_factorials(a, b, c):
return factorial(a) + factorial(b) + factorial(c)
这个函数调用了 factorial 函数来计算 a!、b! 和 c!,然后将它们相加得到最终的结果。
你可以使用这两个函数来计算任意的 a、b 和 c 的阶乘和,例如:
s = sum_factorials(3, 4, 5)
print(s) # Output: 150
希望这些内容能帮助你实现需求。