PAT备考通,4.2 进阶题 - A 英语老师小助手
题目如下:
英语老师要求学生按照如下规则写一串字母:
规则1、如果写了某个大写字母,下一个就必须写同个字母的小写,或者写字母表中前一个字母的大写;
规则2、如果写了某个小写字母,下一个就必须写同个字母的大写,或者写字母表中下一个字母的小写。
例如 zZzZYXWwxyYX
就是一个合法的字母串;而 wVUuvUTsR
就是非法的。
现在面对全班学生交上来的作业,老师请你写个程序自动批改。
输入格式:
输入在第一行给出一个不超过 100 的正整数 N。随后 N 行,每行给出一位学生的作业,即仅由英文字母组成的非空字母串,长度不超过 2×106。
输出格式:
对每位学生的作业,如果正确就在一行中输出 Y
,否则输出 N
。
输入样例:
2
zZzZYXWwxyYX
wVUuvUTsR
输出样例:
Y
N
这是我的代码,样例跑出来是对的,提交是0分= =
#include<stdio.h>
int compare(char x, char y)
{
if ('A' <= x && x <= 'Z')
{
if (y != x + 32 && y != x - 1) { return 0; }
}
if ('a' <= x && x <= 'z')
{
if (y != x - 32 && y != x + 1) { return 0; }
}
}//Y返回非0 N返回0
int main()
{
int N, check = 1;
char x='A', y = 'a',store;
scanf("%d", &N);
while (N > 0)
{
store = getchar();//吸收scanf函数的回车
scanf("%c",&x);//每次输入作业第一个字母
while (check && store != '\n')//check为非0且y不是回车
{
scanf("%c",&y);//输入下一个字母
store = getchar();
check = compare(x, y);//比较两个字母
x = y;//更新x为下一轮比较准备
}
if (check) { printf("Y\n"); }
else { printf("N\n"); }
N--;
}
return 0;
}
思路跟PAT备考通上面差不多,最后翻看了一下答案,答案上提醒了就算本次作业错了,也不能立刻跳出while循环,应该继续把剩下的字母读完,我的好像就是错在这里了,甚至还小聪明的把compare的函数返回值作为判断while循环的条件qwq
今天就这里结束了.