说反话-加强版

7-8 说反话-加强版(20 分)

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

输入格式:

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

输出格式:

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

输入样例:

Hello World Here I Come

输出样例:

Come I Here World Hello
作者: 陈越
单位: 浙江大学
时间限制: 300ms
内存限制: 64MB
代码长度限制: 16KB

太简单不想说了,不知道为什么当时脑子抽了,写不出了,QAQ

#include
#include
#include
#include
using namespace std;
int main()
{
        int i, j;
        char a[1000];
       gets_s(a);
        int l = strlen(a);
        int f = 0;
        for (i = l - 1; i >= 0; i--)
       {
               if ((a[i] == ' ' &&a[i + 1] != ' ' ) || (i == 0&& a[i] != ' ' ))
              {
                       if (f == 1) cout << " " ;
                       if (a[i] == ' ' &&a[i + 1] != ' ' )
                      {
                              for (j = i + 1; j < l&&a[j] != ' ' ; j++) cout << a[j];
                             f = 1;
                      }
                       else
                      {
                              for (j = i; j < l&&a[j] != ' ' ; j++) cout << a[j];
                             f = 1;
                      }
              }
       }
        return 0;
 }

你可能感兴趣的:(PTA)