C语言递归函数求出1~100的和
时间: 2023-06-11 08:08:42 浏览: 179
下面是使用递归函数求解1~100的和的C代码:
```c
#include <stdio.h>
int sum(int n) {
if(n == 1) { //递归结束条件
return 1;
}
return n + sum(n - 1); //递归调用
}
int main() {
int n = 100;
int result = sum(n);
printf("1到%d的和为:%d", n, result);
return 0;
}
```
运行结果为:
```
1到100的和为:5050
```
相关问题
c语言递归函数求斐波那契数列
C语言中可以使用递归函数来求解斐波那契数列。斐波那契数列是一个数列,其中每个数字都是前两个数字的和,起始数字为0和1。以下是使用递归函数求解斐波那契数列的示例代码:
```c
#include <stdio.h>
int fibonacci(int n) {
if (n <= 1) {
return n;
}
return fibonacci(n-1) + fibonacci(n-2);
}
int main() {
int n, i;
printf("请输入要求解的斐波那契数列的项数:");
scanf("%d", &n);
printf("斐波那契数列的前 %d 项为:\n", n);
for (i = 0; i < n; i++) {
printf("%d ", fibonacci(i));
}
return 0;
}
```
在上述代码中,`fibonacci` 函数使用递归的方式来计算斐波那契数列的第 `n` 项。当 `n` 小于等于1时,直接返回 `n`。否则,递归调用 `fibonacci(n-1)` 和 `fibonacci(n-2)` 来计算第 `n` 项的值。
请注意,递归函数在计算大量项时可能会导致性能问题,因为它会重复计算相同的项。可以使用动态规划等其他方法来提高效率。
c语言递归函数求杨辉三角
下面是用C语言递归函数求杨辉三角的代码:
```c
#include <stdio.h>
int YangHui(int i, int j) {
if (j == 0 || j == i) {
return 1;
} else {
return YangHui(i-1, j-1) + YangHui(i-1, j);
}
}
int main() {
int n;
printf("请输入杨辉三角的行数:");
scanf("%d", &n);
for (int i = 0; i < n; i++) {
for (int j = 0; j <= i; j++) {
printf("%d ", YangHui(i, j));
}
printf("\n");
}
return 0;
}
```
首先,我们定义了一个名为`YangHui`的递归函数,它的参数`i`表示杨辉三角的行数,参数`j`表示杨辉三角中当前行的位置,函数返回当前位置的值。
在函数内部,我们首先判断当前位置是否在杨辉三角的边缘,如果是,就返回1,否则就递归计算上一行的相邻两个位置的值之和。
在`main`函数中,我们输入杨辉三角的行数,并使用嵌套的循环打印出整个杨辉三角。