标签:空格 加强版 测试点 输出 ss 单词 L1 include
(还没写完,可以再增加几种方法)
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过500 000的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用若干个空格分开。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子,并且保证单词间只有1个空格。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
测试点:
代码段:
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
vector <string> ss;
int main(){
string s;
while(cin>>s){
ss.push_back(s);
}
reverse(ss.begin(),ss.end());
if(ss.empty()) //如果全为空格时,即堆栈为空时
return 0;
for(int i = 0;i<ss.size()-1;i++){
cout<<ss[i]<<" ";
}
cout<<ss.back();
return 0;
}
1.因为数据量大,所以不能使用数组,否则最后一个测试点无法通过
2.因为是单词,所以数据类型为string类型
3.reserve:反转
4.经过调试,发现只有空格时出现错误,所以增加一个判断,堆栈是否为空
标签:空格,加强版,测试点,输出,ss,单词,L1,include 来源: https://blog.csdn.net/weixin_53225765/article/details/122781095
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。