我的函数获取一个数字并返回输入(包括输入)之前的数字总和;但是,我想知道是否可以计算从 1 开始到 n 结束的连续整数的总和(作为输入)
#include<stdio.h>
int sum(int x){
if(x>0)return x+sum(x-1);
else return 0;
}
main(){
int x;
scanf("%d",&x);;
printf("%dnn",sum(x));
}
我找到了问题的答案,但 stackoverflow.com 不让我回答。所以,我会在这里回答:
这真的很简单,它所需要的只是另一个递增参数和另一个跟踪输入值的参数。
#include<stdio.h>
int sum(int x,int t){
if(t<=x) return t+sum(x,t+1);
else return 0;
}
main(){
int x;
printf("enter int: ");
scanf("%d",&x);
printf("%dn",sum(x,0));
}
所有小于 n
且大于 0
的中间体的总和可以用
int sum = (n*(n+1))/2
它的开销比递归函数少得多。但是,如果您真的想要,那么您的功能看起来是正确的,我会添加一些大括号:
int sum(int x){
if(x>0) {
return x+sum(x-1);
}
else {
return 0;
}
}
上述函数的问题在于,它使用堆栈进行记忆,因此您可能无法计算大n
。你可以使函数尾递归:
int sum(int x, int sum){
if(x>0) {
return sum(x-1, sum + x);
}
else {
return sum;
}
}
这不会使用堆栈来记住您的中间总和。然而,一个简单的循环可能更好,如果你想让它看起来非常神秘和有效,你可以这样做:
int sum = (n*(++n))>>1