从零开始写代码 2023-01-18 22:12 采纳率: 68.2%
浏览 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日

悬赏问题

  • ¥15 高价求中通快递查询接口
  • ¥15 解决一个加好友限制问题 或者有好的方案
  • ¥15 关于#java#的问题,请各位专家解答!
  • ¥15 急matlab编程仿真二阶震荡系统
  • ¥20 TEC-9的数据通路实验
  • ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
  • ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
  • ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
  • ¥20 vitis-ai量化基于pytorch框架下的yolov5模型
  • ¥15 如何实现H5在QQ平台上的二次分享卡片效果?