关于c语言调用递归函数时的程序执行步骤

本文介绍了一种使用C语言递归函数实现字符串反向输出的方法。通过详细解析递归调用过程,从递的过程到归的过程,帮助读者理解递归的基本原理及其在字符串处理中的应用。

示例1:递归反向输出字符串

# include <stdio.h>

void digui(char * p)
{
	if(*p == '\0')
	return;
	else
	{
		digui(p+1);
	    printf("%c",*p);
	}
}

int main()
{
	digui("ABC\0");
	printf("\n");
	return 0;
}

在这里插入图片描述

首先digui()中的参数定义了一个字符指针p,所以其指向的是该字符串“ABC\0”的首地址,所以*p=A(p是指针变量存放的内容是地址,这个不再赘述);

递的过程

然后开始调用进入digui()中,
调用1st:不满足if(*p == ‘\0’)不return,不终止调用,转而执行else语句,然后又进入digui(),这时候字符指针p+1

(在这得读者得自己补充关于理解字符指针和字符数组对于字符串的关系)


调用2st:因为这时候指针指向的是第二个字符B,依然不满足if(*p == ‘\0’)不return,不终止调用,转而执行else语句,然后又进入digui();
调用3st:因为这时候指针指向的是第三个字符C,依然不满足if(*p == ‘\0’)不return,不终止调用,转而执行else语句,然后又进入digui();
调用4st:因为这时候指针指向的是第四个字符 ’ \0 '(空字符),满足if(*p == ‘\0’)return,终止调用;

归的过程

(通俗的理解就是按原路返回)
调用4,因为满足if条件,所以直接终止调用不会printf;
调用3,不满足if条件不终止,执行else语句,输出字符C;
调用2,不满足if条件不终止,执行else语句,输出字符B;
调用1,不满足if条件不终止,执行else语句,输出字符A;

注意

应当强调的是调用一次递归函数不是立即输出printf的值,而是一次又一次的进行递归调用,直到最后不满足条件(通常是if条件)终止调用,然后再按原路返回递推出每次调用的值;
也可以参考:谭浩强《c程序设计》

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SUR0608

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值