给定一个句子(只包含字母和空格), 将句子中的单词位置反转,单词用空格分割, 单词之间只有一个空格,前后没有空格。 比如: (1) “hello xiao mi”-> “mi xiao hello”
输入描述:
输入数据有多组,每组占一行,包含一个句子(句子长度小于1000个字符)
输出描述:
对于每个测试示例,要求输出句子中单词反转后形成的句子
示例1
输入
hello xiao mi
输出
mi xiao hello
#include<iostream>
#include<string>
using namespace std;
void getWord(char split,string sentence,int &num,string all[])
{
// string all[100];
int i = 0,j = 0;
while(sentence[i] != '\0')
{
string one = "";
while(sentence[i] != '\0' && sentence[i] != split)
{
one += sentence[i++];
}
if(sentence[i] == split)
i++;
all[j++] = one;
num++;
}
// return all;
}
void show(string* all,int length)
{
for (int i = length-1; i > -1; --i)
{
cout << all[i];
if(i != 0)
cout << " ";
}
}
int main()
{
string s;
int length = 0;
getline(cin,s);
string all[100];
getWord(' ',s,length,all);
show(all,length);
return 0;
}