##1: 使用递归函数计算1到n之和
本题要求实现一个用递归计算1+2+3+…+n的和的简单函数。
函数接口定义:
int sum( int n );
该函数对于传入的正整数n返回1+2+3+…+n的和;若n不是正整数则返回0。题目保证输入输出在长整型范围内。建议尝试写成递归函数。
裁判测试程序样例:
#include <stdio.h>
int sum( int n );
int main()
{
int n;scanf("%d", &n);
printf ("%d\n", sum(n));return 0;
}/* 你的代码将被嵌在这里 */
输入样例1:
10
输出样例1:
55
输入样例2:
0
输出样例2:
0
作者: 张高燕
单位: 浙江大学城市学院
时间限制: 400 ms
内存限制: 64 MB
代码长度限制: 16 KB
int sum( int n )
{
int result;
if(n<=0)
result=0;
else if(n==1)
result=1;
else
result=sum(n-1)+n;
return result;
}
int sum( int n )
{
int sum=0,i;
if(n<=0)
return 0;
else
for(i=1;i<=n;i++)
sum=sum+i;
return sum;
}
int sum( int n )
{
if(n>=1)return(n+sum(n-1));
else return 0;
}
int sum( int n )
{
int result;
if(n>=1)
result=n+sum(n-1);
else result=0;
return result;
}