c++通过递归求1+2+3+.....+n
时间: 2023-08-05 15:07:08 浏览: 107
你可以使用递归来求解这个问题。下面是一个使用C++实现的示例代码:
```cpp
#include <iostream>
int sum(int n) {
// 递归终止条件
if (n == 0) {
return 0;
}
// 递归调用
return n + sum(n - 1);
}
int main() {
int n;
std::cout << "请输入一个正整数n:";
std::cin >> n;
std::cout << "1+2+3+...+" << n << " = " << sum(n) << std::endl;
return 0;
}
```
该程序会要求用户输入一个正整数n,然后通过递归调用`sum`函数来计算1到n的和,并将结果输出。注意,递归的终止条件是当n等于0时,返回0。每次递归调用时,将n减1,并将结果与n相加,最终得到所求的和。
希望能对你有所帮助!如果还有其他问题,请继续提问。
相关问题
c++用递归的方法求1+2+...+n
您好,关于您的问题,我可以回答。以下是使用递归的方法求1到n的和的C代码:
```
#include <stdio.h>
int sum(int n) {
if (n == 1) {
return 1;
} else {
return n + sum(n-1);
}
}
int main() {
int n;
printf("请输入一个正整数n:");
scanf("%d", &n);
printf("1到%d的和为:%d", n, sum(n));
return 0;
}
```
希望能够帮到您。
用递归函数求1+(1+2)+(1+2+3)+...+(1+2+3+...n)的和
以下是用递归函数求1+(1+2)+(1+2+3)+...+(1+2+3+...n)的和的方法:
```c++
#include <iostream>
using namespace std;
int mysum(int n) {
if (n == 1) {
return 1;
} else {
return n * (n + 1) / 2 + mysum(n - 1);
}
}
int main() {
int n;
cout << "请输入一个值:" << endl;
cin >> n;
cout << "求得的值为:" << mysum(n) << endl;
return 0;
}
```
阅读全文