萌新求助字符串逆序
输入一个字符串,对该字符串进行逆序,输出逆序后的字符串。输入格式:
输入在一行中给出一个不超过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;
}
为什么这种用循环的方法,输出的还是原字符串?
可以使用另外一种方法:
#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;
} 或者这样:
#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: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]