定义一个求阶乘的函数fact(n),并编写测试代码,要求输入整数n(n>=0),分别用递归和非递归的方式实现,用python语言
时间: 2024-05-12 12:21:10 浏览: 135
递归方式实现:
```python
def fact(n):
if n == 0:
return 1
else:
return n * fact(n-1)
n = int(input("请输入一个非负整数:"))
print(fact(n))
```
非递归方式实现:
```python
def fact(n):
result = 1
for i in range(1, n+1):
result *= i
return result
n = int(input("请输入一个非负整数:"))
print(fact(n))
```
测试代码:
```python
#递归方式测试
assert fact(0) == 1
assert fact(1) == 1
assert fact(5) == 120
assert fact(10) == 3628800
#非递归方式测试
assert fact(0) == 1
assert fact(1) == 1
assert fact(5) == 120
assert fact(10) == 3628800
```
相关问题
定义一个求阶乘的函数fact(n),并编写测试代码,要求输入整数n(n>=0)
在C++中,你可以使用递归或循环的方式来定义一个计算阶乘的函数`fact`。这里我将为你提供一个递归版本的实现:
```cpp
#include <iostream>
// 定义计算阶乘的函数
unsigned long long fact(int n) {
if (n == 0 || n == 1) { // 阶乘的基本情况,0和1的阶乘都是1
return 1;
} else {
return n * fact(n - 1); // 递归调用,n的阶乘等于n乘以(n-1)的阶乘
}
}
int main() {
int n;
std::cout << "请输入一个非负整数: ";
std::cin >> n;
if (n < 0) {
std::cerr << "错误!阶乘只对非负整数定义。" << std::endl;
} else {
try {
unsigned long long result = fact(n);
std::cout << "结果是: " << result << std::endl;
} catch (std::overflow_error& e) {
std::cerr << "溢出错误:计算过大的阶乘时可能会发生此情况。" << std::endl;
}
}
return 0;
}
```
这段代码首先定义了一个递归函数`fact`,然后在`main`函数中获取用户输入的整数`n`,检查是否为非负数,如果是则计算阶乘并输出结果,如果输入过大导致`unsigned long long`类型溢出,则捕获异常并提示用户。
编写程序,定义一个求阶乘的函数 fact(n),并编写测试代码,要求输入整数 n(n>=0)
当然可以。在Python中,我们可以使用递归或循环的方式来定义一个计算阶乘的函数。这里我给你两个简单的例子:
**使用递归的方法:**
```python
def fact(n):
if n == 0 or n == 1: # 阶乘的基本情况
return 1
else:
return n * fact(n - 1) # 递归调用
# 测试代码
def test_fact():
for i in range(10): # 测试从0到9的整数阶乘
print(f"Fact of {i}: {fact(i)}")
test_fact()
```
**使用循环的方法:**
```python
def fact(n):
result = 1
for i in range(1, n + 1):
result *= i
return result
# 测试代码
def test_fact_iterative():
for i in range(10):
print(f"Fact of {i}: {fact(i)}")
test_fact_iterative()
```
在这两个例子中,`test_fact()` 和 `test_fact_iterative()` 是用来测试`fact()` 函数是否按预期工作的测试代码,它们分别展示了两种常见的实现阶乘的方式。
阅读全文