python编写一个函数fact,可以计算出给定正整数的阶乘。
时间: 2024-05-13 14:17:00 浏览: 173
下面是一个简单的 Python 函数,可以计算给定正整数的阶乘。它使用了递归算法来实现。
```python
def fact(n):
if n == 1:
return 1
else:
return n * fact(n-1)
# 测试代码
print(fact(5)) # 输出 120
```
在这个函数中,如果输入的参数是1,则直接返回1;否则,递归调用 `fact` 函数,用 `n` 乘以 `fact(n-1)` 的结果,最终得到阶乘的值。
相关问题
Python编写一个函数fact,可以计算出给定正整数的阶乘。
以下是Python编写的计算阶乘的函数:
```python
def fact(n):
if n == 0:
return 1
else:
return n * fact(n-1)
```
这个函数使用递归来计算阶乘。如果给定的数字为0,则阶乘为1;否则,阶乘为n乘以(n-1)的阶乘。
用python解决【问题描述】编写一个函数fact,可以计算出给定正整数的阶乘。 【输入形式】8 【输出形式】40320
可以使用递归或循环来解决这个问题。下面分别给出两种方法的代码实现。
方法一:使用递归
```python
def fact(n):
if n == 1:
return 1
else:
return n * fact(n-1)
n = int(input("请输入一个正整数:"))
result = fact(n)
print("{}的阶乘是:{}".format(n, result))
```
方法二:使用循环
```python
def fact(n):
result = 1
for i in range(1, n+1):
result *= i
return result
n = int(input("请输入一个正整数:"))
result = fact(n)
print("{}的阶乘是:{}".format(n, result))
```
两种方法都可以得到正确的结果,但是递归方法在计算阶乘较大的数时可能会因为递归深度过大而导致程序崩溃。因此,在实际使用中,应该选择使用循环的方法来计算阶乘。
阅读全文