从零开始写代码 2023-01-18 22:12 采纳率: 69.6%
浏览 29
已结题

关于字符串逆向打印的问题(求解)

#include <stdio.h>
#include <string.h> 
void reverse_string(char* str)
{
   char tmp= *str;
   *str=*(str + strlen(str)-1);
   *(str + strlen(str) - 1) = '\0';
   if (strlen(str + 1) >= 2)
   {
    reverse_string(str+1);
   }
   *(str + strlen(str) - 1)=tmp;
}
int main()
{
    char arr[] = "abcdef";
    reverse_string(arr);
    printf("%s\n",arr);
    return 0;
}

这是一个逆向打印字符串abcdef的程序,思想是通过_reverse_string_这个函数将首尾字符交换位置后产生一个新的数组然后打印,但是运行时出现了bug,只打印出了三个字符不知道是哪里错了。

img


此图片是运行结果和代码内容




```c


```

  • 写回答

3条回答 默认 最新

  • 快撑死的鱼 2023-01-18 23:42
    关注

    回答不易,求求您采纳点赞哦

    所提供代码的问题在于它使用递归来反转字符串。该函数的每次递归调用reverse_string都会交换子字符串的第一个和最后一个字符,但不会保留子字符串的其余部分。

    它应该交换子字符串中的字符,然后递归调用子字符串的函数,但它没有这样做。它只是交换子字符串的第一个和最后一个字符,然后为子字符串递归调用函数,但它不保留子字符串的其余部分。

    解决此问题的一种方法是向函数添加一个附加参数,并跟踪子字符串。

    void reverse_string(char* str, int start, int end)
    {
        if(start >= end)
            return;
        char temp = str[start];
        str[start] = str[end];
        str[end] = temp;
        reverse_string(str, start + 1, end - 1);
    }
    
    int main()
    {
        char arr[] = "abcdef";
        reverse_string(arr, 0, strlen(arr) - 1);
        printf("%s\n",arr);
        return 0;
    }
    

    这样你就可以跟踪子字符串并递归调用子字符串上的函数,该函数正在交换子字符串中的字符。

    另一种方法是使用两个指针,一个指向第一个字符,另一个指向最后一个字符,交换字符直到指针彼此交叉。

    void reverse_string(char* str)
    {
        int len = strlen(str);
        int i = 0;
        int j = len - 1;
        while(i < j){
            char temp = str[i];
            str[i] = str[j];
            str[j] = temp;
            i++;
            j--;
        }
    }
    
    int main()
    {
        char arr[] = "abcdef";
        reverse_string(arr);
        printf("%s\n",arr);
        return 0;
    }
    

    这样您就可以使用两个指针交换字符并且不会丢失任何字符。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 1月27日
  • 已采纳回答 1月19日
  • 创建了问题 1月18日

悬赏问题

  • ¥30 STM32 INMP441无法读取数据
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境