浅析C语言函数递归

目录

0 理解要点

1 示例一:打印整型数据的字符

1.1 源代码

1.2 代码说明

1.2.1 代码逻辑结构说明

1.2.2 代码执行顺序

1.3 结果说明

2 示例二:计算字符串长度

2.1 函数分析

2.2 分析→代码

2.3 代码逻辑结构及执行顺序说明

2.4 结果说明


0 理解要点

1、默认情况下,C语言的代码执行顺序为自上至下。

2、递归的逻辑其实就是嵌套,是一层一层的,千万不要类比循环去理解。

1 示例一:打印整型数据的字符

1.1 源代码

void fun(int a,int b)
{
	b++;
	printf("%d ", b);
	if(a>9)
	{
		fun(a / 10,b);
	}
	printf("\n%d", a);
}

int main()
{
	fun(123,1);
    return 0;
}

1.2 代码说明

1.2.1 代码逻辑结构说明

如图所示:

(1) 灰色的表示第一层函数、黄色表示第二层、绿色表示第三层。

(2) 每一层fun函数都由三个实现模块组成,分别是b++ 与 printf(b)、if结构、printf(a).

1.2.2 代码执行顺序

(以下文字的背景色与上述代码逻辑结构的说明的颜色一一对应)

1.3 结果说明

由代码执行顺序分析可得最终打印结果为:

2 3 4

1

12

123

这与文章一开始强调的自上而下、嵌套逻辑的说明是完全吻合的。

2 示例二:计算字符串长度

示例一主要为了说明递归的逻辑,接下来的示例则主要说明设计原理。

2.1 函数分析

假设自定义的函数为MyStrlen,那么字符串byte的长度可表达为

MyStrlen(byte\0)

=1+MyStrlen(yte\0)

=1+1+MyStrlen(te\0)

=1+1+1+MyStrlen(e\0)

=1+1+1+1+MyStrlen(\0)

由上述分析,首先可以明确的是,需要MyStrlen(\0)=0.

2.2 分析→代码

int MyStrlen(char* arr)//由于数组元素的值无法传递过来,因此以数组的地址作为参数
{
    if (*arr != '\0')//数组地址=数组首个元素的地址,解引用得到的也是数组的首元素
        return 1 + MyStrlen(arr + 1);//地址+1,表示向后移动一个存储单元,对数组而言,就是下一个元素的地址
    else
        return 0;//这里对应的是 MyStrlen(\0)=0
}

int main()
{
    char str[]="byte";
    int len=MyStrlen(str);
    printf("%d", len);
	return 0;
}

2.3 代码逻辑结构及执行顺序说明

这里依然遵循自上而下、嵌套逻辑的规则。

分析方法与示例一基本类似,因此,仅以图示加以说明,✕表示不执行,✓表示执行。

目录

0 理解要点

1 示例一:打印整型数据的字符

1.1 源代码

1.2 代码说明

1.2.1 代码逻辑结构说明

1.2.2 代码执行顺序

1.3 结果说明

2 示例二:计算字符串长度

2.2 分析→代码

2.3 代码逻辑结构及执行顺序说明

2.4 结果说明

显而易见,最终的打印结果为 1+1+1+1+0=4.

此外,由于下部的代码均为else, 当满足if的情况时,else不执行,不存在自上向下。因此,实际仅仅是从内向外执行的嵌套逻辑。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值