C:浅谈递归

根据《C Primer Plus》总结整理

什么是递归?

C允许函数调用自己,这种调用过程叫做递归。可以使用循环的地方通常都可以使用递归只不过有时使用循环更好,有时使用递归更好。

演示递归

//  recur.c程序 演示递归

#include<stdio.h>
void up_and_down (int);

int main(void)
{
	up_and_down(1);
	return 0;
}

void up_and_down(int n)
{
	printf("Level %d: n location %p\n", n, &n); // #1
	if(n < 4)
	   up_and_down(n + 1);
	printf("LEVEL %d: n location %p\n", n, &n);  // #2
	
}

输出如下

Level 1: n location 000000000062FE00
Level 2: n location 000000000062FDD0
Level 3: n location 000000000062FDA0
Level 4: n location 000000000062FD70
LEVEL 4: n location 000000000062FD70
LEVEL 3: n location 000000000062FDA0
LEVEL 2: n location 000000000062FDD0
LEVEL 1: n location 000000000062FE00

--------------------------------
Process exited after 0.009927 seconds with return value 0
请按任意键继续. . .

分析一下

首先, main() 使用参数 1 调用了函数 up_and_down() ,于是 up_and_down() 中形式参数 n 的值是 1, 故打印语句 #1 输出了 Level1 。然后,由于 n 的数值小于 4 ,所以 up_and_down() (第 1 级)使用参数 n+1 即数值 2 调用了 up_and_down()( 第 2 级 ). 使得 n 在第 2级调用中被赋值 2, 打印语句 #1 输出的是 Level2 。与之类似,下面的两次调用分别打印出 Level3 和 Level4 。

当开始执行第 4 级调用时, n 的值是 4 ,因此 if 语句的条件不满足。这时候不再继续调用 up_and_down() 函数。第 4 级调用接着执行打印语句 /* 2 */,即输出 Level4 ,因为 n 的值是 4 。现在函数需要执行 return 语句,此时第 4 级调用结束,把控制权返回给该函数的调用函数,也就是第 3 级调用函数。第 3 级调用函数中前一个执行过的语句是在 if 语句中进行第 4 级调用。因此,它继续执行其后继代码,即执行打印语句 /* 2 */,这将会输出 Level3 当第 3 级调用结束后,第 2 级调用函数开始继续执行,即输出Level2 .依次类推.

主要的点在于:当你up_and_down(1)调用up_and_down(2)时,up_and_down(2)没结束就得调用up_and_down(3),也就是说,你#2语句还没输出呢。(函数没走完呢)

当n=4的时候,跳出if开始输出#2语句,输出完#2,up_and_down(4)函数算结束了,然后该走up_and_down(3)了,然后输出第二次#2。以此类推,直到输出最后一次#2。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值