字符串逆序的的递归写法

前言

递归写法讲起来有点麻烦,我开始写的时候脑袋都想晕了。

但其实画几遍图就能找到突破口。

递归函数一般分两部分,一个是调用函数前的部分,一个是函数调用后的部分,

从我的理解来说,函数调用前的部分是从头开始,到尾结束,而函数调用后的部分正相反。

这个题我的思路就是在前序部分将a[i]的值用一个tmp储存,然后用a[0]接收a[n-i-1]的值.

然后在后序部分,用a[n-i-1]接收tmp里的值,这样就形成了头尾的替换。

1.前序部分

2.后序部分

 

void Reverse_String(char *str)
{
    char tmp = *str;
    int len = strlen(str);
    *str = *(str + len - 1);
    *(str + len - 1) = '\0';//通过将'\0'前移和strlen控制字符串下标
    if (strlen(str + 1) >= 2)//步长小于2时,递归结束
    {
        Reverse_String(str + 1);
    }
    *(str + len - 1) = tmp;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值