PAT乙级1009 || 说反话(C语言)

个人主页:mzwang.top

说反话

题目描述:

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

输入格式:

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

输出格式:

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

输入样例:

Hello World Here I Come

输出样例:

Come I Here World Hello

题目来源:PAT乙级1009
作者:CHEN, Yue
单位:浙江大学

问题解决:

解题思想

方法1 (见下面代码1)
使用二维数组通过scanf函数输入,遇到一个空格即为一个单词的输入结束,PAT是单点测试,我们知道多点测试的评测系统经常会使用到EOF,scanf函数是有返回值的,它的返回值是其成功读入的参数的个数,scanf函数在读取文件时达到文件末尾导致的无法读取的现象会产生读入失败,读入失败时scanf函数会返回-1,C语言用EOF来表示-1,因此,可用while(scanf("%s",str[i]) != EOF)来判断输入是否结束。

:此法代码虽然简单,但有一个点容易出错,如果将如下代码

while(scanf("%s",str[i]) != EOF){
    i++
}

写成:

while(scanf("%s",str[i++]) != EOF);

将导致评测系统评测不通过。对于此题,用上面的输入样例检测,上面代码退出循环时i的值是5,而下面的代码退出循环时i的值是6,想一想为什么?可以用笔模拟一下这个过程。

方法2 (见下面代码2)
使用一维数组,在每个即将输出的单词后面加一个字符串结束符'\0'(否则会输出包含此单词在内后面所有字符串,直到遇到字符串结束符'\0'),用printf函数输出字符串。此法的关键点是控制好i的位置。

代码示例(C)

小提示:左右滑动代码可查看全部内容
代码1

#include <stdio.h>
#define MAXN 85
int main()
{
    char str[MAXN][MAXN];
    int i = 0;
    //使用EOF来判断输入是否结束
    while(scanf("%s",str[i]) != EOF){
        i++;
    }
    i--;//i退回到最后一个单词的下标
    while(i >= 0){
        //注意要控制输出格式
        printf("%s",str[i]);
        if(i > 0){
            printf(" ");
        }
        i--;
    }
    return 0;
}

代码2

#include <stdio.h>
#include <string.h>
#define MAXN 85

int main()
{
    int i,flag = 0;
    char str[MAXN];
    gets(str);
    for(i = strlen(str); i >= 0; i--){
        //在即将输出的单词尾部加一个字符串结束符'\0'
        //i移过即将输出的单词
        str[i] = '\0';
        while((str[i] != ' ')&&(i >= 0)){
            i--;
        }
        //如果由于遇到空格退出循环,则i移至即将输出单词的第一个字符
        if(str[i] == ' '){
            i++;
        }
        //否则i < 0,则即将输出的为第一个单词,i移至其首字符
        else{
            i=0;
        }
        if(flag == 0){
            printf("%s",&str[i]);
            flag = 1;
        }
        else{
            printf(" %s",&str[i]);
        }
    }
    return 0;
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PAT乙级1009题是一个关于字符串处理的题目。根据题目要求,我们需要将输入的字符串按照单词的逆序输出。根据提供的引用内容,我们可以看到有三种不同的解法。 引用\[1\]和引用\[2\]是两个相似的解法,使用了字符串处理函数strchr和strrchr来定位空格字符,并将字符串分割成单词。然后通过循环输出单词,最后输出剩余的最后一个单词。 引用\[3\]是另一种解法,使用了二维数组来存储每个单词。通过循环读取输入的字符串,直到遇到换行符为止。然后通过倒序循环输出每个单词。 根据题目要求,你可以选择其一种解法来完成PAT乙级1009题。 #### 引用[.reference_title] - *1* [PAT考试乙级1009(C语言实现)](https://blog.csdn.net/JeffreyDDD/article/details/78395267)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [PAT乙级1009C语言实现)](https://blog.csdn.net/weixin_62870950/article/details/124934829)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [PAT乙级测试1009C语言实现)](https://blog.csdn.net/weixin_45947840/article/details/105943475)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值