给出1个C语言简单递归题目和完整答案以及解析,不要斐波那契数列
时间: 2024-05-03 22:23:11 浏览: 54
C语言的递归示例,简单易懂
4星 · 用户满意度95%
题目:编写一个递归函数,求一个正整数的阶乘。
答案:
```c
#include <stdio.h>
int fact(int n) {
if (n == 0 || n == 1) {
return 1;
}
else {
return n * fact(n-1);
}
}
int main() {
int n;
printf("请输入一个正整数:");
scanf("%d", &n);
printf("%d的阶乘是%d\n", n, fact(n));
return 0;
}
```
解析:本题需要使用递归的思想,即在函数内部调用自身。递归要有一个递归出口,即当传入的参数满足某个条件时,不再递归,直接返回结果。在本题中,递归出口是当传入的参数为0或1时,直接返回1。否则,将n乘以n-1的阶乘,即为n的阶乘。在主函数中,先输入一个正整数n,然后调用fact函数计算n的阶乘并输出。
阅读全文