用c语言编写一个自定义的递归函数fun(n),该函数的功能是求整数n的阶乘,在主函数main中调用此自定义函数,求解1!+2!+3!+......n!,运行时n由用户从键盘输入,如果输入的不是整数,则屏幕输出“输入非法!请重新输入!”
时间: 2023-09-30 20:01:48 浏览: 54
好的,我可以帮你解决这个问题。以下是代码:
```c
#include <stdio.h>
int fun(int n) {
if (n == 1) {
return 1;
} else {
return n * fun(n - 1);
}
}
int main() {
int n, sum = 0;
printf("请输入一个整数n:");
if (scanf("%d", &n) != 1) {
printf("输入非法!请重新输入!\n");
return 0;
}
for (int i = 1; i <= n; i++) {
sum += fun(i);
}
printf("1! + 2! + ... + %d! = %d\n", n, sum);
return 0;
}
```
首先定义了一个递归函数 `fun(n)`,用于计算整数 n 的阶乘。在主函数 `main` 中,首先要求用户输入一个整数 n,如果输入的不是整数,则输出“输入非法!请重新输入!”并结束程序。如果输入的是整数,则通过循环计算 1! + 2! + ... + n! 的值,最后输出结果。
希望这个代码能够帮到你!
相关问题
编写一个C语言程序,实现编写一个自定义的递归函数fun(n),该函数的功能是求整数n的阶乘,在主函数main中调用此自定义函数,求解1!+2!+3!+......n!,运行时n由用户从键盘输入,如果输入的不是整数,则屏幕输出“输入非法!请重新输入!”
以下是实现该功能的C语言程序:
```c
#include <stdio.h>
long long fun(int n); // 自定义递归函数
int main() {
int n;
long long sum = 0;
printf("请输入一个整数n:");
if (scanf("%d", &n) != 1) { // 判断输入是否为整数
printf("输入非法!请重新输入!\n");
return 0;
}
if (n < 0) { // 判断输入是否为负数
printf("输入非法!请重新输入!\n");
return 0;
}
for (int i = 1; i <= n; i++) {
sum += fun(i);
}
printf("1!+2!+3!+...+%d!的和为%lld\n", n, sum);
return 0;
}
long long fun(int n) {
if (n == 0) {
return 1;
} else {
return n * fun(n - 1);
}
}
```
程序运行时,会要求用户输入一个整数n,如果输入的不是整数,则会输出“输入非法!请重新输入!”;如果输入的是负数,则同样会输出“输入非法!请重新输入!”。如果输入的是正整数,则会计算出1!+2!+3!+...+n!的和并输出。其中,递归函数fun(n)的作用是计算n的阶乘。
帮我用C语言写一个程序:编写一个自定义的递归函数fun(n),该函数的功能是求整数n的阶乘,在主函数main中调用此自定义函数,求解1!+2!+3!+......n!,运行时n由用户从键盘输入,如果输入的不是整数,则屏幕输出“输入非法!请重新输入!”
好的,下面是使用C语言编写的程序,可以实现您的需求:
```
#include <stdio.h>
int fun(int n)
{
if (n == 0 || n == 1)
return 1;
else
return n * fun(n - 1);
}
int main()
{
int n, sum = 0;
printf("请输入一个正整数n:");
if (scanf("%d", &n) != 1 || n < 0) {
printf("输入非法!请重新输入!\n");
return 0;
}
for (int i = 1; i <= n; i++) {
sum += fun(i);
}
printf("1!+2!+3!+...+n! = %d\n", sum);
return 0;
}
```
以上程序中,我们定义了一个自定义的递归函数`fun(n)`,实现求整数n的阶乘。在主函数`main`中,我们首先通过`scanf`函数从键盘读入用户输入的正整数n。如果输入的不是整数或者小于0,程序会输出“输入非法!请重新输入!”并退出。如果输入的是一个正整数,我们就可以通过循环调用自定义函数`fun(i)`,并将每次调用的结果相加,最终求出1!+2!+3!+...+n!的值,并输出结果。
希望能够帮到您!
阅读全文
相关推荐
![-](https://img-home.csdnimg.cn/images/20241231044937.png)
![-](https://img-home.csdnimg.cn/images/20241231044937.png)
![-](https://img-home.csdnimg.cn/images/20241231045021.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![doc](https://img-home.csdnimg.cn/images/20241231044833.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![docx](https://img-home.csdnimg.cn/images/20241231044901.png)
![-](https://img-home.csdnimg.cn/images/20241231044833.png)
![-](https://img-home.csdnimg.cn/images/20241231045021.png)
![-](https://img-home.csdnimg.cn/images/20241231045021.png)