C语言大神帮忙看下,运行结果多少,能说下怎么算的步骤吗。谢谢了!

intf(intn){if(n==2)return1;elsereturnf(n-2)+n;}main(){printf("%d\n",f(10));}... int f(int n)
{ if(n==2) return 1;
else return f(n-2)+n;}
main()
{ printf("%d\n",f(10));}
展开
 我来答
ivyxtvv
2015-06-26 · TA获得超过1177个赞
知道小有建树答主
回答量:78
采纳率:0%
帮助的人:93万
展开全部
这是一个简单的递归,运行结果是f(10),
看f这个函数,如果不等于2,就再调用f(10-2)即f(8)
还不明白的话,一步步来看,首先执行f(10),此时n=10,所以运行结果是
f(8)+10;接着执行f(8),f(8)的执行结果是8+f(6)...以此类推,最终结果是
10+8+6+4+f(2),而f(2)就是1,所以结果是29
你在f函数最后加一个printf("%d",n);运行一遍就明白了
zhuhengxuan
2015-06-26 · 能源领域入门c语言;历史规律,高考志愿
zhuhengxuan
采纳数:102 获赞数:399

向TA提问 私信TA
展开全部
29,计算过程是,递推10+8+6+4+1
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式