PTA 说反话-加强版 (20 分)

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

输入格式:

测试输入包含一个测试用例,在一行内给出总长度不超过500 000的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用若干个空格分开。

输出格式:

每个测试用例的输出占一行,输出倒序后的句子,并且保证单词间只有1个空格。

输入样例:

Hello World   Here I Come

输出样例:

Come I Here World Hello
#include<iostream>
#include<sstream> //istringstream 必须包含这个头文件
#include<cstring>
#include<string>
#include<stack>

using namespace std;

int main(){
	string str;
	stack<string> s;
	getline(cin,str);
	istringstream it(str);  //注意这里用的是括号(),it是定义的变量名 
	while(it >> str){ //str必须是提前定义好的一个string类型变量 
		s.push(str);  
	}
	int flag=0;
	while(!s.empty()){
		if(flag==0){
			flag=1;
			cout<<s.top();
		}else{
			cout<<" "<<s.top();
		} 
		s.pop();
	}
	return 0;
}

istringstream的构造函数原形如下:
istringstream::istringstream(string str);
它的作用是从string对象str中读取字符。

猜你喜欢

转载自blog.csdn.net/ru_ruo1/article/details/86553202