首页 > 代码库 > 1009. 说反话 (20) (ZJUPAT 字符串处理)

1009. 说反话 (20) (ZJUPAT 字符串处理)

题目链接:http://pat.zju.edu.cn/contests/80/1009


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

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

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

输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello


代码如下:

#include <cstdio>
#include <cstring>
char mm[87][87];
char s[87];
int main()
{
    while(gets(s))
    {
        memset(mm,'\0',sizeof(mm));
        int cont = 0, k = 0;
        int len = strlen(s);
        for(int i = 0; i < len; i++)
        {
            if(s[i] == ' ')
            {
               // mm[cont][k] = '\0';
                cont++;
                k = 0;
            }
            else
                mm[cont][k++]=s[i];
        }
        printf("%s",mm[cont]);
        for(int i = cont-1; i >= 0; i--)
        {
            printf(" %s",mm[i]);
        }
        printf("\n");
    }
    return 0;
}


1009. 说反话 (20) (ZJUPAT 字符串处理)