小米-句子反转

https://www.nowcoder.com/practice/0ae4a12ab0a048ee900d1536a6e98315?tpId=85&tqId=29896&tPage=1&rp=1&ru=/ta/2017test&qru=/ta/2017test/question-ranking

题目描述

给定一个句子(只包含字母和空格), 将句子中的单词位置反转,单词用空格分割, 单词之间只有一个空格,前后没有空格。 比如: (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;
}

猜你喜欢

转载自blog.csdn.net/reigns_/article/details/83015433