翻转字符串

给定一个字符串 str,实现对字符串的翻转,例如对字符串 abc 进行翻转之后将变为 cba

解题思路

方法:中间递归

每次调用 reverse() 函数,把字符串的第 0 个字符保存到 c_temp,并把最后一个字符填充到第 0 个字符的位置,同时用 '\0' 来填充最后一个字符的位置。

调用 reverse() 的实参为 str + 1,这会导致形参 str 的指向发生改变,每次递归调用时 str 都会向后移动一个字符的位置。

每次递归调用都会处理一个新的子串,这个新的子串时在原来字符串的基础上 "掐头去尾" 所形成的。

#include <stdio.h>
#include <string.h>

char *reverse(char *str) {
    // Write your code here
    int len = strlen(str);
    if(len > 1)
    {
        char c_temp = str[0];
        str[0] = str[len - 1];
        str[len - 1] = '\0';
        reverse(str + 1);
        str[len - 1] = c_temp;
    }
    return str;
}

int main() {
    char str[101];
    scanf("%[^\n]", str);
    printf("%s\n", reverse(str));
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值