大家都知道,镜子能把内容左右颠倒,比如,你拿着一个单词"apple",用它的最后侧的字符'e'贴着镜子,看到的字符串一定是"elppa",我们把颠倒后的单词,称之为镜像单词。 现在有n个字符串,每个字符串中包含了若干被镜像的单词,请你编程将这些单词恢复原状。 请注意,不是整个字符串“颠倒”了,而是字符串中的每个单词“颠倒了”。 比如:有如下字符串"olleH kcaJ",这个字符串就包含了2个被“颠倒”的单词,将这两个单词恢复原状,结果应该是"Hello Jack"。
输入格式
第1行有一个整数n(n<=500)表示接下来有n行字符串需要我们来处理。 接下来n行,每行有一个字符串,字符串中包含了若干被“颠倒”的单词,单词之间使用一个或多个空格分隔。(一行最多有1000个字符)
输出格式
输出n行,每行表示对输入每行字符串处理的结果。
输入数据 1
3
olleh !dlrow
I ekil .bulcmca
I evol .mca
Copy
输出数据 1
hello world!
I like acmclub.
I love acm.
代码示例:
#include<bits/stdc++.h>
using namespace std;
int main(){
int n;
cin>>n;
getchar();
string s;
while(n--){
getline(cin,s);
s+=" ";
int len=s.size(),l=0,r;
for(int i=0;i<len;i++){
if(s[i]==' '){
r=i-1;
reverse(s.begin()+l,s.begin()+r+1);
l=i+1;
}
}
cout<<s<<endl;
}
return 0;
}