m0_73376921 2023-01-22 19:15 采纳率: 83.3%
浏览 42
已结题

使用递归的方法,将数组里的字符倒序

问题遇到的现象和发生背景

使用递归的方法,将数组里的字符倒序

遇到的现象和发生背景,请写出第一个错误信息
用代码块功能插入代码,请勿粘贴截图。 不用代码块回答率下降 50%
#include<stdio.h>
#include<string.h>
int stringh(char arr[])
{
    int count = 0;
    while (*arr != '\0')
    {
        count++;
        arr++;
    }
    return count;
}
void reverse_string(char *arr)
{
    char tmp = arr[0];
    int sz = stringh(arr);
    arr[0] = arr[sz - 1];
    arr[sz - 1] = '\0';
    while (stringh(arr + 1) >= 2)
        reverse_string(arr + 1);
    arr[sz - 1] = tmp;
}
int main()
{
    char arr[] = "admc";
    reverse_string(arr);
    printf("%s\n", arr);
    return 0;
}
运行结果及详细报错内容

无法打印出结果,但是数组中字符串长度小于等于3,可以打印出来

我的解答思路和尝试过的方法,不写自己思路的,回答率下降 60%

使用递归的方法,将数组里的字符倒序

  • 写回答

2条回答 默认 最新

  • 元气少女缘结神 2023-01-22 22:30
    关注
    
    #include <stdio.h>
    #include <stdlib.h>
    #include <assert.h>
     
    int strlenh(const char* str)
    {
        assert(str);
        int count = 0;
        while (*str++)
        {
            count++;
        }
        return count;
    }
     
    void reverse_string(char *str)
    {
        assert(str != NULL);
        int len = strlenh(str);
        char tmp = *str;
        *str = *(str + len - 1);
        *(str + len - 1) = '\0';
        if (strlenh(str + 1) > 1)
        {
            reverse_string(str + 1);
        }
        *(str + len - 1) = tmp;
     
    }
    int main()
    {
        char arr[] = "abcdef";
        reverse_string(arr);
        printf("%s\n", arr);
        system("pause");
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 1月22日
  • 已采纳回答 1月22日
  • 创建了问题 1月22日

悬赏问题

  • ¥50 hyper默认的default switch
  • ¥15 网站打不开,提示502 Bad Gateway
  • ¥20 基于MATLAB的绝热压缩空气储能系统代码咨询
  • ¥15 R语言建立随机森林模型出现的问题
  • ¥20 unity内置语言切换的按钮设置
  • ¥15 中级微观经济学,生产可能性边界问题
  • ¥15 TCP传输时不同网卡传输用时差异过大
  • ¥15 请各位看看我写的属于什么算法,或者有更正确的写法?
  • ¥15 html5 qrcode 扫描器
  • ¥15 爬取网页信息并保存需要完整代码