英语老师要求学生按照如下规则写一串字母:
规则1、如果写了某个大写字母,下一个就必须写同个字母的小写,或者写字母表中前一个字母的大写;
规则2、如果写了某个小写字母,下一个就必须写同个字母的大写,或者写字母表中下一个字母的小写。
例如 zZzZYXWwxyYX
就是一个合法的字母串;而 wVUuvUTsR
就是非法的。
现在面对全班学生交上来的作业,老师请你写个程序自动批改。
输入格式:
输入在第一行给出一个不超过 100 的正整数 N。随后 N 行,每行给出一位学生的作业,即仅由英文字母组成的非空字母串,长度不超过 2×106。
输出格式:
对每位学生的作业,如果正确就在一行中输出 Y
,否则输出 N
。
输入样例:
2
zZzZYXWwxyYX
wVUuvUTsR
输出样例:
Y
N
代码长度限制
16 KB
时间限制
800 ms
内存限制
64 MB
def panduan(n):
a = []
for i in range(n):
a.append(input())
for i in a:
p=[]
flag = 0
for j in range(len(i)):
p.append(i[j])
for k in range(len(p)):
if 65<= ord(p[k])<=90 and k+1<len(p):
if ord(p[k+1])!=ord(p[k])+32 and ord(p[k+1])!=ord(p[k])-1 :
flag=1
break
else:
flag = 0
if 97<= ord(p[k])<=122 and k+1<len(p):
if ord(p[k+1])!=ord(p[k])-32 and ord(p[k+1])!=ord(p[k])+1 and k+1==len(p):
flag=1
break
else: flag=0
if flag==1:
print("N")
else:
print("Y")
panduan(int(input()))