• 手机版

    扫码体验手机版

  • 微信公众号

    扫码关注公众号

国内首家协议开发

软芯音视解码保护平台

在线
客服

发布
需求

在线
聊天

天盟
APP

天盟APP下载

关注
微信

微信扫一扫访问
顶部

我写了一个1+.....+100的递归函数但是n在1,2处有些不明白,求前辈们帮助?

#include
int summary(int n)
{
int sum;
if(n==1)
{
  sum = 1;
}
else
{
  sum = n+summary(n-1);//在n=1时,sum=1,在n=2时,sum=2+summary(1),也就是说summary(1)就等于sum就等于1?感觉很不对诶!
}
return sum;
}
int main ()
{
int n = 100;
printf("1+......+100的结果为%d\n:",summary(n));
return 0;
}


求大神解答....

免责声明:本内容仅代表回答会员见解不代表天盟观点,请谨慎对待。

版权声明:作者保留权利,不代表天盟立场。

使用道具 举报

全部参与3

”sum=2+summary(1),也就是说summary(1)就等于sum就等于1“
不要当成数学公式看,程序里的sum是个局部变量,每一次递归调用的sum都是不同的sum变量。关注一下变量的作用域。

使用道具 举报

假设n>0
summary(n)=n+summary(n–1)
=n+(n-1)+summary(n–2)
=n+(n–1)+(n–2)+…+3+summary(2)
=n+(n–1)+(n–2)+…+3+2+summary(1)
=n+(n–1)+(n–2)+…+3+2+1
=n(n+1)/2
递归总有一个基本条件用于判断递归原点,不然递归是无意义的。

使用道具 举报

看晕了。快带我去医院

使用道具 举报

发新帖

发布任务需求已有1031289位用户正在使用天盟网服务

发布分类: *
任务预算: *
需求内容: *
手机号码: *
任务商家报价为
  • 预算价 :
  • 成交价 :
  • 完工期 :
  • 质保期 :

* 最终任务项目以服务商报价、双方协商为准!