题目描述
给定一个句子(只包含字母和空格), 将句子中的单词位置反转,单词用空格分割, 单词之间只有一个空格,前后没有空格。 比如: (1) “hello xiao mi”-> “mi xiao hello”
输入描述:
输入数据有多组,每组占一行,包含一个句子(句子长度小于1000个字符)
输出描述:
对于每个测试示例,要求输出句子中单词反转后形成的句子
示例1
输入
hello xiao mi
输出
mi xiao hello
题解:
#include <iostream>
#include <vector>
#include <cstring>
using namespace std;
int main(){
string s;
while(getline(cin, s)){
vector<string> v;
string idx = "";
for (int i = 0; i < s.length(); i++){
if (s[i] != ' '){
idx += s[i];
}
else {
v.push_back(idx);
idx.clear();
}
}
v.push_back(idx);
for (int i = v.size() - 1; i > 0; i--){
cout << v[i] << ' ';
}
cout << v[0] << endl;
}
return 0;
}