S=1+2+3+…+n;
#include <stdio.h>
main()
{
unsigned long i,n,s=0;
scanf("%u", &n);
for(i=0;i<=n;i++)
s+=i;
printf("%u", s);
}
把变量i,n,s定义为无符号长整型,n最大值为92681
也可以把变量i,n,s定义为单精度实型,
scanf("%f", &n);
…
printf("%f", s);
n的最大值比92681大,但不到100000;
但当把i,n,s定义为双精度实型时,输出的结果却是0.000000,不知问题在哪
#include <stdio.h>
main()
{
unsigned long n,s;
scanf("%u", &n);
if(n%2==0)
s=n/2*(n+1);
else
s=(n+1)/2*n;
printf("%u", s);
}
这种方法求和n的最大值同上。
函数递归调用求和一
#include <stdio.h>
sum(int i)
{
static int m=0;
m+=i;
i–;
if(i)
sum(i);
}
main()
{
int s,n;
scanf("%d",&n);
s=sum(n);
printf("%d",s);
}
函数递归调用求和二
#include <stdio.h>
sum(int i)
{
int m=0;
for(i)
m=i+sum(i-1);
}
main()
{
int s,n;
scanf("%d",&n);
s=sum(n);
printf("%d",s);
}