“答案正确”是自动判题系统给出的最令人欢喜的回复。本题属于 PAT 的“答案正确”大派送 —— 只要读入的字符串满足下列条件,系统就输出“答案正确”,否则输出“答案错误”。
得到“答案正确”的条件是:
- 字符串中必须仅有
P
、A
、T
这三种字符,不可以包含其它字符; - 任意形如
xPATx
的字符串都可以获得“答案正确”,其中x
或者是空字符串,或者是仅由字母A
组成的字符串; - 如果
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