句子反转 应该是小米的。。。。。。。。

题目描述

给定一个句子(只包含字母和空格), 将句子中的单词位置反转,单词用空格分割, 单词之间只有一个空格,前后没有空格。 比如: (1) “helloxiao mi”-> “mi xiao hello”

输入描述:

输入数据有多组,每组占一行,包含一个句子(句子长度小于1000个字符)

输出描述:

对于每个测试示例,要求输出句子中单词反转后形成的句子
示例1

输入

复制
hello xiao mi

输出

复制
mi xiao hello


/*#include<bits/stdc++.h>
using namespace std;
int main()
{
    string a;
    vector<string>b;
    while(cin>>a)
     b.push_back(a);
    for(int i=b.size()-1;i>=1;i--)
        cout<<b[i]<<" ";
    cout<<b[0]<<endl;
    return 0;
}*///上面只能一组输入,还对了,懵逼
#include<bits/stdc++.h>
using namespace std;

int main(){
    string a;
    while(getline(cin,a)){
        reverse(a.begin(),a.end());//相当于反转作用
         int i=0,j=i;
       while(i<a.size()){
                //cout<<a<<endl;
           while(i<a.size()&&a[i]!=' ')//遍历整个string数组,遇到空格将之前的反转
               ++i;
            reverse(a.begin()+j,a.begin()+i);
            j=++i;
        }
        cout<<a<<endl;
    }
    return 0;
}




猜你喜欢

转载自blog.csdn.net/zhangao230/article/details/80752510