#include<stdio.h>
int f(int a[],int n)
{
if(n>1)
{
int t;
t=f(a,n-1);
return t>a[n-1]?t:a[n-1];
}
else return a[0];
}
int main()
{
int a[]={8,2};
printf("%d\n",f(a,2));
}
//8
这个题我第一开始做,蒙了,不会,因为嵌套调用中自我调用,感觉这个名词我会,但是一到做题才知道,我是真的不会。
其实这个题考的很简单,就是不满足if条件时,直接返回到他的调用处,就是t=f(a,n-1);
解析:2>1可以,t=f(8,1),再次调用f函数,1>1不满足,这时要返回t=f(8,1),而不是结束,判断return语句,因为最后一次时不满足返回给t为a[0]=8,所以就是8>a[1]?8:a[1];
就可以得出结果。
嵌套调用语句
最新推荐文章于 2024-06-27 08:45:43 发布