从零开始写代码 2023-01-18 22:12 采纳率: 72.7%
浏览 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 tensorflow
  • ¥15 densenet网络结构中,特征以cat方式复用后是怎么进行误差回传的
  • ¥15 STM32G471芯片spi设置了8位,总是发送16位
  • ¥15 R语言并行计算beta-NTI中tree文件的类型
  • ¥15 如何解读marsbar导出的ROI数据?
  • ¥20 求友友协助弄一下基于STC89C52单片机的声光控制灯原理图
  • ¥15 arduino双向交通灯设计
  • ¥15 有没有会粒子群算法的大能(○゜ε^○)求带不会出收敛图😭
  • ¥15 Matlab读取根元素出错