勿理338 2022-05-25 15:16 采纳率: 100%
浏览 196
已结题

递归函数求1到n的累加

#include<stdio.h>
int sum(int n){
if(n==1)
return 1;
else
return n+sum(n-1);
return n;
}
main()
{
int n;
printf("输入一个整数 n:");
scanf("%d",&n);
printf("输出的结果为:%d\n",sum(n));
}
函数的意思,核心,以及核心的意思是什么。急用,本人啥也不懂

  • 写回答

9条回答 默认 最新

  • 树下等苹果 2022-05-25 15:55
    关注

    程序运行过程:
    (1)执行:printf("输入一个整数 n:"); 输出提示
    (2)执行:scanf_s("%d", &n); 输入一个整数
    (3)执行:printf("输出的结果为:%d\n", sum(n)); 在这步调用了sum()函数,并将n的值传递给函数。然后进入到函数里面。
    (4)进入sum()函数内部:对n的值进行判断,如果n=1,则函数返回1,即printf("输出的结果为:%d\n", sum(n))输出的值等于1;如果n!=1(n不等于1),则返回:n+sum(n-1),即printf("输出的结果为:%d\n", sum(n))的值应该为n + sum(n - 1),但是又调用了sum()函数,并将n-1传递函数,继续重复之前的步骤,返回n-1+sum(n-2),即输出的值应该为n+n-1+sum(n-2),然后又继续进入sum函数。直到n=1。
    综上:所以执行这个函数的结果就是求:n+n-1+n-2..+1。也就是说这个函数是用来求1+2+...+n的和。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(8条)

报告相同问题?

问题事件

  • 系统已结题 6月3日
  • 已采纳回答 5月26日
  • 创建了问题 5月25日