给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:测试输入包含一个测试用例,在一行内给出总长度不超过80的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用1个空格分开,输入保证句子末尾没有多余的空格。
输出格式:每个测试用例的输出占一行,输出倒序后的句子。
输入样例:Hello World Here I Come输出样例:
Come I Here World Hello //简单题, 每个人的解题思路都不一样,我的代码只能作为参考,还望多指出不足!#include <iostream> #include <string> #include <vector> using namespace std; vector<string> v; int main() { string s, tem = ""; getline(cin, s); for(int i = 0; i < s.length(); ++i) { if(s[i] == ' ') { if(tem == "") { continue; } v.push_back(tem); tem = ""; } else if( i == s.length()-1 && s[i] != ' ') { tem += s[i]; v.push_back(tem); tem = ""; } else tem += s[i]; } while(v.size()) { if(v.size() == 1) { cout<<v.back(); v.pop_back(); } else { cout<<v.back()<<" "; v.pop_back(); } } cout<<endl; return 0; }