给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
作者: CHEN, Yue
单位: 浙江大学
时间限制: 400 ms
内存限制: 64 MB
代码长度限制: 16 KB
换行结束掉输入
栈的基本操作
#include <iostream>
#include <stack>
using namespace std;
int main()
{
stack<string> v;
string s;
while(cin >> s)
{
v.push(s);
if(getchar()=='\n') break;
}
cout << v.top();
v.pop();
while(!v.empty())
{
cout << " " << v.top();
v.pop();
}
return 0;
}
或者用vector做
#include <cstdio>
#include <cstring>
#include <vector>
#include <iostream>
using namespace std;
vector<string> vi;
string s;
int main()
{
while(cin>>s)
{
vi.push_back(s);
if(getchar()=='\n')
{
break;
}
}
for(int i=vi.size()-1;i>=0;i--)
{
cout<<vi[i];
if(i) printf(" ");
}
return 0;
}
参考:柳婼 原博地址:https://blog.youkuaiyun.com/liuchuo/article/details/51994658
本文介绍了一种算法,用于将给定的英语句子中所有单词的顺序进行颠倒输出,提供了使用栈和vector两种数据结构实现的方法。
326

被折叠的 条评论
为什么被折叠?



