C语言中递归函数

递归就是通过函数自己的重复调用,直到不符合判断结果,结束递归。

如下是用递归计算一个字符串长度的案例

int my_strlen(char* str)
{
 if(*str !='\0')
 {
  return 1+my_strlen(str+1);
 }
 else
 {
 return 0;
 }
}
int main()
{
 char arr[]="abc";
 int len= my_strlen(arr);
 printf("%d",len);
 return 0;
}

 这里的函数调用传的字符串首元素的地址,也就是a的地址,进入my_strlen函数后进行if判断a!='\0';进入if语句里面,然后重新调用自己(也就是my_strlen(str+1));这里要注意的是str+1代表地址是b的地址了,b!='\0';进行进入if判断,然后又调用自己,直到if判断为假,输出0;返回到调用自己的函数里面去,也就是谁调用了自己就返回到那里。

就是当str代表的是c的地址的时候调用了my_strlen(str+1),my_strlen(str+1)的返回值0要返回来,str是c的地址的上一级调用是str是b的地址时候,返回到b所在的函数里面来。

递归函数要注意的是要有一个判断条件来就是调用,返回的值也要不断的接近判断条件

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值