鱼C论坛

 找回密码
 立即注册
查看: 1390|回复: 3

[已解决]萌新求助字符串逆序

[复制链接]
发表于 2020-2-16 19:56:17 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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

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

为什么这种用循环的方法,输出的还是原字符串?
最佳答案
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++)
改下再试试
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-2-16 20:13:23 | 显示全部楼层
可以使用另外一种方法:
#include <stdio.h>
#include "string.h"
int main()
{
    int i, n;
    char str[81], c;
    gets(str);
    n = strlen(str);
    for (i = (n - 1); i >= 0; i--)
    {
        printf("%c", str[i]);
    }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-16 20:21:55 | 显示全部楼层
或者这样:
#include <stdio.h>
#include "string.h"
int main()
{
    int i, n, j;
    char str[81], c, new_str[81];
    gets(str);
    n = strlen(str);
    for (i = (n - 1), j = 0; i >= 0; i--, j++)
    {
        new_str[j] = str[i];
    }
    puts(new_str);
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 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++)
改下再试试
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-16 01:40

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表