编辑这个页面须要登录或更高权限!
在此示例中,您将学习使用递归函数查找自然数之和。
要理解此示例,您应该了解以下C语言编程主题:
正数1、2、3 ...称为自然数。下面的程序从用户处获取一个正整数,然后计算得出给定数字的总和。
访问此页面可 使用循环查找自然数之和。
#include <stdio.h> int addNumbers(int n); int main() { int num; printf("输入一个正整数: "); scanf("%d", &num); printf("Sum = %d", addNumbers(num)); return 0; } int addNumbers(int n) { if (n != 0) return n + addNumbers(n - 1); else return n; }
输出结果
输入一个正整数: 20 Sum = 210
假设用户输入了20。
最初,从main()调用addNumbers(),并传入20作为参数。
数字20被添加到addNumbers(19)的结果中。
在下一个从addNumbers()到addNumbers()的函数调用中,将传递19,该值将添加到addNumbers(18)的结果中。 此过程一直持续到n等于0。
当n等于0时,没有递归调用。 这最终将整数和返回给main()函数。