浙大版《C语言程序设计(第4版)》题目集参考答案
本题要求实现一个用递归计算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
提交结果:
基本思路:
大于1递归,小于等于0返回0
代码实现:
int sum( int n )
{
if(n<=0)//归
{
return 0;
}
else//递
{
return n+sum(n-1);
}
}
欢迎提问和纠错,共同讨论一起进步!