零的执行人 发表于 2020-2-16 19:56:17

萌新求助字符串逆序

输入一个字符串,对该字符串进行逆序,输出逆序后的字符串。
输入格式:
输入在一行中给出一个不超过80个字符长度的、以回车结束的非空字符串。
输出格式:
在一行中输出逆序后的字符串。
输入样例:
Hello World!
输出样例:
!dlroW olleH

方法2
#include <stdio.h>
#include "string.h"
int main()
{
    int i,n;
    char str,c;
    gets(str);
    n=strlen(str);
    for(i=0;i<n;i++){
      c=str;
      str=str;
      str=c;
    }
    puts(str);
    return 0;
}

为什么这种用循环的方法,输出的还是原字符串?

zltzlt 发表于 2020-2-16 20:13:23

可以使用另外一种方法:

#include <stdio.h>
#include "string.h"
int main()
{
    int i, n;
    char str, c;
    gets(str);
    n = strlen(str);
    for (i = (n - 1); i >= 0; i--)
    {
      printf("%c", str);
    }
    return 0;
}

zltzlt 发表于 2020-2-16 20:21:55

或者这样:

#include <stdio.h>
#include "string.h"
int main()
{
    int i, n, j;
    char str, c, new_str;
    gets(str);
    n = strlen(str);
    for (i = (n - 1), j = 0; i >= 0; i--, j++)
    {
      new_str = str;
    }
    puts(new_str);
    return 0;
}

4goodworld 发表于 2020-2-16 21:14:00

本帖最后由 4goodworld 于 2020-2-16 21:17 编辑

我测试了下,发现你有一个设计上的问题
假设是ABCD
请问,你需要操作几次循环就OK?
答案是2次,
第一次,A - D 对换 变成 DBCA
第二次,B - C 对换 变成 DCBA
搞定了
你再看看你的算法
n=strlen(str);
    for(i=0;i<n;i++)
啥意思
其实当i=2的时候,你已经完成对换了,结果你不
i=3
DCBA 也就是 B与C 再换回来,变成DBCA
同理
i=4,将A与D再换一边,变成ABCD
感觉没有变。
最后解法:
for(i=0;i<(n/2);i++)
改下再试试
页: [1]
查看完整版本: 萌新求助字符串逆序