. 编写求 n!的函数 f(int n),在主函数中输入两个整数 m、n,然后调用函数求: 其中:m 为学号后 2 位,n 可以任意指定。 【注意】函数 f 的类型应用 long 或 double 。 n!(m- n)! m! C
时间: 2024-10-17 16:10:05 浏览: 18
求!+!+!++n!-过程和函数
首先,为了编写求阶乘的函数`f`,我们需要考虑`long`或`double`类型,因为阶乘的结果可能会很大,尤其是当`n`很大的时候。这里我会提供一个`long`类型的函数,因为它可以处理更大的数值,尽管对于非常大的`n`,即使是`long`也可能溢出。
```c++
#include <iostream>
// 定义求n!的函数
long long factorial(int n) {
if (n == 0 || n == 1) { // 特殊情况,0! 和 1! 等于1
return 1;
} else {
return n * factorial(n - 1); // 递归计算阶乘
}
}
int main() {
int m, n;
std::cout << "请输入学号后两位和想要计算阶乘的值: ";
std::cin >> m >> n;
// 计算两个阶乘并相乘
long long result = factorial(m % 100) * factorial((m - n) % 100);
std::cout << "结果是: " << result << std::endl;
return 0;
}
```
在这个程序中,我们先读取用户输入的学号后两位`m`和想要计算阶乘的值`n`。然后利用`factorial`函数分别计算`m`和`(m - n)`的阶乘,并将它们相乘得到最终结果。
阅读全文