给定一个字符串,翻转该字符串,翻转时单词中的字符顺序不变。例如,如果字符串为"Hello World",则翻转后为"World Hello"。单词间以一个或多个空格分隔。注意,字符串开头和结尾都可能有多个空格。输出时去掉多余的空格。只在每个单词之间以1个空格间隔。输出的每行末尾没有空格。
输入格式:
输入可能包括多行。每行代表一个字符串,除了空格外,标点符号和普通字母一样处理。你可以认为一行的字符总数不会超过50000个,单词数不会超过600,每个单词的长度也不会超过30。
输出格式:
输出包括多行,每行对应输入的一行,为翻转后的字符串。输出时去掉多余的空格。只在每个单词之前以1个空格间隔。输出的每行末尾没有空格。
输入样例:
在这里给出一组输入。例如:
student. a am I
World Hello
输出样例:
在这里给出相应的输出。例如:
I am a student.
Hello World
#include <stdio.h>
int main()
{
char word[50001];
while(gets(word) != '\0') {
int n = strlen(word);
int end = n,flag = 0;
for(int i = n - 1; i >= 0; i--) {
if((word[i - 1] == ' ' && word[i] != ' ') || (i == 0 && word[i] != ' ')) {
if(flag == 1) printf(" ");
for(int j = i; j < end; j++) {
if(word[j] != ' ')
printf("%c", word[j]);
}
flag = 1;
end = i - 1;
}
}
printf("\n");
}
return 0;
}