【PAT乙级】说反话

正文索引 [隐藏]

题目描述:

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

输入描述:

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

输出描述:

每个测试用例的输出占一行,输出倒序后的句子。

输入样例:

Hello World Here I Come

输出样例:

Come I Here World Hello

解题思路:

看完题目之后就可以无脑用Python了。分步骤讲解一下吧,input().split()可以理解为将输入的一行字符串以空格为分隔符添加到一个列表temp里,” “.join(temp[::-1])是把列表temp中的元素倒序添加到一个以空格为分隔符的字符串里,这个字符串也就是最后的结果。用C艹求解的话可以利用栈“先进后出”的性质,先把字符串中的单词全部推入栈中,然后再清栈大甩卖疯狂输出即可邪恶

PyAC代码:

print(" ".join(input().split()[::-1]))

 CppAC代码:

#include <bits/stdc++.h>
using namespace std;
int main()
{
    stack<string> s;
    string str;
    while(cin >> str)
    {
        s.push(str);
    }
    bool isVirgin = true;
    while(!s.empty())
    {
        if(isVirgin)
        {
            cout << s.top();
            isVirgin = false;
        }
        else
        {
            cout << " " << s.top();
        }
        s.pop();
    }
    return 0;
}