“答案正确”是自动判题系统给出的最令人欢喜的回复。本题属于 PAT 的“答案正确”大派送 —— 只要读入的字符串满足下列条件,系统就输出“答案正确”,否则输出“答案错误”。

得到“答案正确”的条件是:

  1. 字符串中必须仅有 P、 A、 T这三种字符,不可以包含其它字符;
  2. 任意形如 xPATx 的字符串都可以获得“答案正确”,其中 x 或者是空字符串,或者是仅由字母 A 组成的字符串;
  3. 如果 aPbTc 是正确的,那么 aPbATca 也是正确的,其中 a、 b、 c 均或者是空字符串,或者是仅由字母 A 组成的字符串。

现在就请你为 PAT 写一个自动裁判程序,判定哪些字符串是可以获得“答案正确”的。

输入格式:

每个测试输入包含 1 个测试用例。第 1 行给出一个正整数 n (<),是需要检测的字符串个数。接下来每个字符串占一行,字符串长度不超过 100,且不包含空格。

输出格式:

每个字符串的检测结果占一行,如果该字符串可以获得“答案正确”,则输出 YES,否则输出 NO

具体代码如下:

#/bin/bash

func_pipei(){
p_index=$(expr index "$line" "P") #返回首次匹配到P
t_index=$(expr index "$line" "T") #返回首次匹配到T
#${string:position:length} 在$string中, 从位置$position开始提取长度为$length的子串
strA=${line:0:$(expr $p_index - 1)}
strB=${line:p_index:$(expr $t_index - $p_index - 1)}
strC=${line:$t_index}
if [[ $(expr ${#strA} \* ${#strB} ) -eq ${#strC} ]] #此处判断 a*b=c
then
echo "YES"
else
echo "NO"
fi
} read -p"请输入字符串内容,多行字符串以空格分隔:" n
for line in $(echo $n)
do
length=$(echo $line |awk '{print length($0)}')
length_p=$(echo ${line//P/} |awk '{print length($0)}')
length_t=$(echo ${line//T/} |awk '{print length($0)}')
#判断是否存在A P T 三个字符,排除替换语句报错
if [[ $(expr index $line "APT") -ne 0 ]]
then
#条件1,把A P T字符替换为空,判断是否为空
#条件2,3 判断P T 字符的个数是否为1
#条件4 判断A的字符个数是否不为0
#条件5 判断P的位置在T的前面
if [[ -z ${line//[APT]/} ]] && [[ $(expr $length - $length_p) -eq 1 ]] && [[ $(expr $length - $length_t) -eq 1 ]] && [[ $(expr index $line "A" ) != 0 ]] || [[ $length_t -gt $length_p ]]
then
func_pipei
else
echo "NO"
fi
else
echo "NO"
fi
done

em...虽然示例数据获得了结果,但是没有通过,不过也算练习了。

这里,我忽略了一个问题,就是题目中,首行是数字,是对下方字符串的统计,这里没有进行处理。所以获取不到正确的结果。也就是说for循环需要跳过第一个字符。

wyf349@ubuntu:~/user/study_shell$ bash  1003_rightanswer.err1.sh
请输入字符串内容,多行字符串以空格分隔:PAT PAAT AAPATAA AAPAATAAAA xPATx PT Whatever APAAATAA
YES
YES
YES
YES
NO
NO
NO
NO

  问题:

    1.主要是字符串的相关操作,获取字符串的位置 expr index命令,字符串长度  ${#var} ,字符串替换${string//substring/replacement};

    2.关于shell的多行脚本读写输入问题,目前只想到了通过分隔符来读取多个字符串,但是类似示例中的,按行区分,暂时没想到解决办法。

#!/bin/bash
read -d / -p "分隔行读取:" n #-d参数可以直接指定结束符
for i in $(echo $n)
do
echo "--------------"
echo "$i"
done
解答:关于分行读取的问题,可以将文本看作输入一行处理一行,没必要看做输入多行,再按照多行处理

  

-------------------------------

以下是正确答案:

#/bin/bash

func_pipei(){
p_index=$(expr index "$line" "P") #返回首次匹配到P
t_index=$(expr index "$line" "T") #返回首次匹配到T
strA=${line:0:$(expr $p_index - 1)}
strB=${line:p_index:$(expr $t_index - $p_index - 1)}
strC=${line:$t_index}
if [[ $(expr ${#strA} \* ${#strB} ) -eq ${#strC} ]] #此处判断 a*b=c
then
echo "YES"
else
echo "NO"
fi
} read num
for ((i >=0;i<$num;i++))
do
read line
length=$(echo $line |awk '{print length($0)}')
length_p=$(echo ${line//P/} |awk '{print length($0)}')
length_t=$(echo ${line//T/} |awk '{print length($0)}')
#判断是否存在A P T 三个字符,排除替换语句报错
if [[ $(expr index $line "T") -gt $(expr index $line "P") ]]
then
if [[ -z ${line//[APT]/} ]] && [[ $(expr $length - $length_p) -eq 1 ]] && [[ $(expr $length - $length_t) -eq 1 ]] && [[ $(expr index $line "A" ) != 0 ]]
then
func_pipei
else
echo "NO"
fi
else
echo "NO"
fi done

  此题可分析出几个测试点:

    1.正确的输入输出问题;

    2.字符‘P A T’是否满足表达式 :以PT作为分割线,第1段A个数 *  第2段个数 = 第3段的个数问题

    3.满足条件 位置P 再位置T的左边;

    4.满足条件,P和T的个数为1个;

    5.满足条件,A的个数要大于0个。

补充调整为python的版本:

#!/usr/bin/python3
#-*- coding:utf-8 -*- def check_PAT(line): #判断位置与公式
position_P=line.find('P')
position_T=line.find('T')
#根据位置关系计算字符数的计算公式是否成立
strA=line.split('P')[0]
strB=line[position_P + 1:position_T]
strC=line.split('T')[-1] if (len(strA) * len(strB) == len(strC) ) and (position_T > position_P):
return True
else:
return False def main():
num=int(input())
for i in range(num):
line=str(input())
#判断是否为PAT三个字母构成
line_c=line.replace('P','').replace('T','').replace('A','')
if len(line_c)==0:
#判断P T的个数
if line.count('P')==1 and line.count('T')==1 and line.count('A') > 0 and check_PAT(line):
print('YES')
else:
print('NO')
else:
print('NO') if __name__ == '__main__':
main()

  

shell练习--PAT题目1003:我要通过!(成功案例)的更多相关文章

  1. shell练习--PAT题目1001:卡拉兹(Callatz)猜想(失败案例)

    卡拉兹(Callatz)猜想: 对任何一个正整数 n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把 ( 砍掉一半.这样一直反复砍下去,最后一定在某一步得到 n=1.卡拉兹在 1950 年的世界 ...

  2. shell练习--PAT题目1007:关于素数对(失败案例)

    让我们定义d​n​​为:d​n​​=p​n+1​​−p​n​​,其中p​i​​是第i个素数.显然有d​1​​=1,且对于n>1有d​n​​是偶数.“素数对猜想”认为“存在无穷多对相邻且差为2的素 ...

  3. shell练习--PAT题目1005:继续(3n+1)猜想(全绿失败喜加一)

    卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对 n=3 进行验证的时 ...

  4. shell练习--PAT题目1008:数组元素循环右移问题 (失败案例,运行超时)

    一个数组A中存有N(>)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(≥)个位置,即将A中的数据由(A​0​​A​1​​⋯A​N−1​​)变换为(A​N−M​​⋯A​N−1​​A ...

  5. 2019年7月25日 shell练习--PAT题目1006:换个格式输出整数(失败案例)

    让我们用字母 B 来表示“百”.字母 S 表示“十”,用 12...n 来表示不为零的个位数字 n(<),换个格式来输出任一个不超过 3 位的正整数.例如 234 应该被输出为 BBSSS123 ...

  6. shell练习--PAT题目1004: 成绩排名 !(失败案例,shell运行超时)

    读入 n(>)名学生的姓名.学号.成绩,分别输出成绩最高和成绩最低学生的姓名和学号. 输入格式: 每个测试输入包含 1 个测试用例,格式为 第 1 行:正整数 n 第 2 行:第 1 个学生的姓 ...

  7. shell练习--PAT题目1002:写出这个数(失败案例)

    读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字. 输入格式: 每个测试输入包含 1 个测试用例,即给出自然数 n 的值.这里保证 n 小于 1. 输出格式: 在一行内输出 n 的 ...

  8. PAT 乙级 1003

    题目 题目地址:PAT 乙级 1003 题解 规律观察题,本题的关键在于把题读懂,同时还有几个比较容易疏忽的地方需要注意:总之这道题要考虑的东西更多,细节上也要特别注意: 规律:“如果 aPbTc 是 ...

  9. 图论 - PAT甲级 1003 Emergency C++

    PAT甲级 1003 Emergency C++ As an emergency rescue team leader of a city, you are given a special map o ...

随机推荐

  1. PEP8-python编码规范(下)

    1.结尾逗号 结尾的逗号通常是可选的,除了在构成一个元素的元组时是强制性需要的(在Python 2 中,它们对 print 语句有语义).为了清晰起见,建议将后者用括号括起来(在技术上是多余的). Y ...

  2. 【神经网络与深度学习】【python开发】caffe-windows使能python接口使用draw_net.py绘制网络结构图过程

    [神经网络与深度学习][python开发]caffe-windows使能python接口使用draw_net.py绘制网络结构图过程 标签:[神经网络与深度学习] [python开发] 主要是想用py ...

  3. QT use of undeclared identifier 'cout'

    在QT 5.12中直接使用cout将提示错误如下: 添加库 #include<iostream>,并将cout&end改为std::cout&std::endl 代码如下: ...

  4. Luogu P3953 [NOIP2017]逛公园

    题目 首先我们跑出从\(1\)出发的最短路\(d1\)和反图上从\(n\)出发的最短路\(dn\). 然后我们处理出长度不超过\(d1_n+k\)的最短路边集,给它拓扑排序. 如果存在环,那么这个环一 ...

  5. java按值传递?

    原文链接:https://blog.csdn.net/scholar_man/article/details/80900212 在Java中,参数都是按值传递的.被传递到方法中的拷贝值,要不就是一个引 ...

  6. RabbitMQ入门教程(十四):RabbitMQ单机集群搭建

    原文:RabbitMQ入门教程(十四):RabbitMQ单机集群搭建 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://b ...

  7. static修饰的成员与非static修饰类的成员的区别

    ① 格式 : 1> static修饰的,称为静态成员,非static修饰的,称为非静态成员. ② 内存位置: 1>static修饰的,在方法区的静态区中,非static修饰的,在堆中的对象 ...

  8. Linux上安装JDK1.8,tomcat9,以及mysql8的步骤

    (该篇是在centos7上安装JDK1.8.0_201  tomcat9.0.16 和 mysql8.0.15) 一.安装JDK 方式一 1.首先,下载JDK(链接http://www.oracle. ...

  9. ms17_0199样本测试

    一大早就各种消息弹框,于是就来测试一波 https://github.com/nixawk/metasploit-framework/blob/8ab0b448fdce15999f155dfd7b22 ...

  10. 2019-11-29-VisualStudio-解决方案筛选器-slnf-文件

    title author date CreateTime categories VisualStudio 解决方案筛选器 slnf 文件 lindexi 2019-11-29 08:41:13 +08 ...