c语言代码.用递归求1+2+3+n
时间: 2024-01-13 16:04:34 浏览: 99
以下是使用递归求1+2+3+n的C语言代码:
```c
#include <stdio.h>
int sum(int n) {
if (n == 1) {
return 1;
} else {
return n + sum(n - 1);
}
}
int main() {
int n = 100;
int result = sum(n);
printf("1+2+3+...+%d=%d", n, result);
return 0;
}
```
相关问题
c语言递归求1+2²+3²+...+n²
这是一个经典的递归问题。可以使用递归函数来解决。递归函数的基本思路是:如果n等于1,则返回1的平方;否则,返回n的平方加上n-1的平方和。下面是一个C语言递归求1+2²+3²+...+n²的示例代码:
```
#include <stdio.h>
int sum(int n) {
if (n == 1) {
return 1;
} else {
return n * n + sum(n - 1);
}
}
int main() {
int n = 10;
printf("1^2 + 2^2 + ... + %d^2 = %d\n", n, sum(n));
return 0;
}
```
这个程序使用了递归函数sum来计算1²+2²+3²+...+n²的值。在sum函数中,如果n等于1,则返回1的平方;否则,返回n的平方加上n-1的平方和。在主函数中,我们调用sum函数来计算1²+2²+3²+...+n²的值,并将结果打印出来。
C语言用递归实现1+2+3+...+n的和
以下是C语言用递归实现1+2+3+...+n的和的代码和解释:
```c
#include <stdio.h>
#include <stdlib.h>
int fun(int m); // 声明递归函数
int main(){
int n,sum=0;
printf("Please enter a number:");
scanf("%d",&n);
if(n<=0){
printf("Enter error");
exit(0);
}
sum=fun(n); // 调用递归函数
printf("sum=%d\n",sum);
return 0;
}
int fun(int m){
if(m==1){ // 递归结束条件
return 1;
}
return m+fun(m-1); // 递归调用
}
```
解释:
1.首先在主函数中输入一个正整数n,如果n小于等于0,则输出“Enter error”并退出程序。
2.然后调用递归函数fun(n),将返回值赋给变量sum。
3.在递归函数fun(m)中,如果m等于1,则返回1,递归结束。
4.否则,返回m+fun(m-1),即m加上m-1到1的和,继续递归调用fun(m-1)。
5.最终,fun(n)返回的值就是1+2+3+...+n的和,赋给sum并输出。
阅读全文