马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
int main()
{
extern int fun2(int n);
fun2(100);
}
// 第二种在归的时候解决问题
int fun2(int n)
{
if(n>=1)
{
return fun2(n-1);
printf("%d ",n);
}
}
为什么递归到当n=0的时候,然后继续递归到100呢
在给出答案之前,我想提醒你的代码存在一些问题:
首先,在函数fun2的定义中,当n>=1时,它会递归调用自身并返回结果。但是,当n=0时,函数没有明确定义返回值,这可能导致不确定的行为。
其次,在递归调用之后,你尝试使用printf语句打印当前的n值。然而,由于递归调用发生在return语句之前,所以在n-1的递归调用过程中,printf语句是不会被执行的。
针对你的问题,当n递归到0时,递归调用会终止,因为在函数定义中只有当n>=1时才进行递归。此时,程序将从递归函数的最底层开始回溯,层层返回,继续执行之前未执行的语句。在这个例子中,回溯到n=1的递归调用,执行其中的printf("%d ", n);语句,打印出数字"1"。接着回溯到n=2的递归调用,打印出数字"2",依此类推,直到回溯到n=100的初始调用,最终打印出所有数字从1到100。
所以,尽管n在递归的过程中递减到0,但回溯的过程使得函数在返回之前能够打印出所有数字。
如果问题已经解决,请设置最佳答案
|