PAT(Basic Level) Practice——1009 说反话

版权声明:余生请多指教,欢迎交流学习: https://blog.csdn.net/LYS20121202/article/details/84438333

原题目:

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

输入格式:

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

输出格式:

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

输入样例:

Hello World Here I Come

输出样例:

Come I Here World Hello

分析:

1.记得别的语言有可以分割字符串的方法,C语言没注意有什么好用的,只有硬核编程解题了,太菜了,没别的。

代码:

C语言版:

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int N,M,i=0,j,k=100,s=0;
    char Str[100];
    gets(Str);//读取字符串
    s=strlen(Str);//获取字符串长度
    s--;//从最后一个字符开始
    for(i=s,k=s;i>=0;i--)//从最后一个字符开始循环,直到字符打印完成
    {
        if(Str[i]==' ')//若遇到空格,则将i+1到K的字符打印,并更新K值为空格的前一位
        {
            for(j=i+1;j<=k;j++)
            {
                printf("%c",Str[j]);
            }
            k=i-1;
            printf(" ");
        }
        else if(i==0)//对于第一单词,也就是反过来的最后一个是不用打印空格的,所以单独处理
        {
            for(j=i;j<=k;j++)
            {
                printf("%c",Str[j]);
            }
            k=i-1;
        }

    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/LYS20121202/article/details/84438333