【PAT】我要通过!
“答案正确”是自动判题系统给出的最令人欢喜的回复。本题属于PAT的“答案正确”大派送 —— 只要读入的字符串满足下列条件,系统就输出“答案正确”,否则输出“答案错误”。
得到“答案正确”的条件是:
1. 字符串中必须仅有P, A, T这三种字符,不可以包含其它字符;
2. 任意形如 xPATx 的字符串都可以获得“答案正确”,其中 x 或者是空字符串,或者是仅由字母 A 组成的字符串;
3. 如果 aPbTc 是正确的,那么 aPbATca 也是正确的,其中 a, b, c 均或者是空字符串,或者是仅由字母 A 组成的字符串。
现在就请你为PAT写一个自动裁判程序,判定哪些字符串是可以获得“答案正确”的。
输入格式:每个测试输入包含1个测试用例。第1行给出一个自然数n(<10),是需要检测的字符串个数。接下来每个字符串占一行,字符串长度不超过100,且不包含空格。
输出格式:每个字符串的检测结果占一行,如果该字符串可以获得“答案正确”,则输出YES,否则输出NO。
输入样例:
8
PAT
PAAT
AAPATAA
AAPAATAAAA
xPATx
PT
Whatever
APAAATAA
输出样例:
YES
YES
YES
YES
NO
NO
NO
NO
初看题目我是这么理解的:
- 由条件 (1) (2) 知,有 2 种基本情况是 “正确” 的,即 PAT 和 xPATx;
- 由条件 (3) 知,其余 “正确” 情况都是由那 2 种基本情况不断演变而来。
因此我想到的是递归暴力法:
- 首先判断 2 种基本情况为 “正确”。
- 要想 aPbATca “正确”,就要 aPbTc “正确”,于是用 string.find() 找到 aPbATca 中 'P' 和 'AT' 的下标,通过 string.substr() 截取字符串获得 aPbTc,递归判断 aPbTc 是否 “正确”。
#include <iostream>
#include <string> using namespace std; bool onlyA(string s) {
for (int i = ; i < s.size(); i++)
if (s[i] != 'A')
return false;
return true;
} bool isCorrect(string s) {
if (s == "PAT") return true;
else if (s.find("PAT") != string::npos) {
int idx = s.find("PAT");
string x1 = s.substr(, idx), x2 = s.substr(idx + );
if (onlyA(x1) && onlyA(x2) && x1 == x2)
return true;
}
else if (s.find("P") != string::npos) {
int p_idx = s.find("P");
string a1 = s.substr(, p_idx);
string a2 = s.substr(s.size() - p_idx);
if (onlyA(a1) && onlyA(a2) && a1 == a2 && s.find("AT") != string::npos) {
int at_idx = s.find("AT");
string b = s.substr(p_idx + , at_idx - p_idx - );
string ca = s.substr(at_idx + );
string c = ca.substr(, ca.size() - a2.size());
if (isCorrect(a1 + "P" + b + "T" + c))
return true;
}
else {
return false;
}
}
return false;
} int main() {
int n;
cin >> n;
string *s = new string[n];
for (int i = ; i < n; i++)
cin >> s[i];
for (int i = ; i < n; i++) {
if (isCorrect(s[i]))
cout << "YES" << endl;
else
cout << "NO" << endl;
}
return ;
}
后来查看网上解析,总结题意发现:
- 基本情况是 xPATx,x 只含有 'A' 或为空。这里我们用 a、b、c 表示原题中相应位置 'A' 的数量,则初始情况下,a = c,b = 1。
- 由条件(3),'P' 和 'T' 中间每增加 1 个 'A',即 b + 1 后,整个字符串结尾要添加 1 个 'P' 前的字符串,即 c 变为 c + a。
由初始状态 b = 1,且若 b = b + 1,则 c = c + a,可知 c = a × b。
挖掘到这个深层信息,改写 isCorrect() 函数如下,效率会更高。
// C style
bool isCorrect(string s) {
int a = , b = , c = ;
bool hasP = false, hasAT = false;
for (int i = ; i < s.size(); i++) {
if (!hasP) {
if (s[i] == 'A') {
a++;
continue;
}
else if (s[i] == 'P') {
hasP = true;
continue;
}
else {
return false;
}
}
else {
if (!hasAT) {
if (s[i] == 'A') {
b++;
continue;
}
else if (s[i] == 'T' && s[i - ] == 'A') {
hasAT = true;
continue;
}
else {
return false;
}
}
else {
if (s[i] == 'A') {
c++;
continue;
}
else {
return false;
}
}
}
}
if (hasP && hasAT && a * b == c)
return true;
else
return false;
} // C++ style
bool isCorrect(string s) {
int idxP = s.find("P"), idxAT = s.find("AT");
if (idxP != string::npos && idxAT != string::npos) {
for (int i = ; i < idxP; i++) {
if (s[i] != 'A')
return false;
}
for (int i = idxP + ; i < idxAT; i++) {
if (s[i] != 'A')
return false;
}
for (int i = idxAT + ; i < s.size(); i++) {
if (s[i] != 'A')
return false;
}
// a * b == c
if (idxP * (idxAT - idxP) == (s.size() - idxAT - ))
return true;
}
return false;
}
【PAT】我要通过!的更多相关文章
- 《转载》PAT 习题
博客出处:http://blog.csdn.net/zhoufenqin/article/details/50497791 题目出处:https://www.patest.cn/contests/pa ...
- PAT Judge
原题连接:https://pta.patest.cn/pta/test/16/exam/4/question/677 题目如下: The ranklist of PAT is generated fr ...
- PAT/字符串处理习题集(二)
B1024. 科学计数法 (20) Description: 科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式[+-][1-9]"."[0-9]+E[+ ...
- PAT 1041. 考试座位号(15)
每个PAT考生在参加考试时都会被分配两个座位号,一个是试机座位,一个是考试座位.正常情况下,考生在入场时先得到试机座位号码,入座进入试机状态后,系统会显示该考生的考试座位号码,考试时考生需要换到考试座 ...
- PAT 1040. 有几个PAT(25)
字符串APPAPT中包含了两个单词"PAT",其中第一个PAT是第2位(P),第4位(A),第6位(T):第二个PAT是第3位(P),第4位(A),第6位(T). 现给定字符串,问 ...
- PAT 1032. 挖掘机技术哪家强(20)
为了用事实说明挖掘机技术到底哪家强,PAT组织了一场挖掘机技能大赛.现请你根据比赛结果统计出技术最强的那个学校. 输入格式: 输入在第1行给出不超过105的正整数N,即参赛人数.随后N行,每行给出一位 ...
- pat甲级题解(更新到1013)
1001. A+B Format (20) 注意负数,没别的了. 用scanf来补 前导0 和 前导的空格 很方便. #include <iostream> #include <cs ...
- PAT (Basic Level) Practise 1040 有几个PAT(DP)
1040. 有几个PAT(25) 时间限制 120 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 字符串APPAPT中包含了两个单 ...
- PAT (Basic Level) Practise 1045 快速排序(离散化+主席树区间内的区间求和)
1045. 快速排序(25) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 著名的快速排序算法里有一个经典的划分 ...
- PAT——乙级真题1003代码
#include<iostream> #include<string> using namespace std; int getLength(string str0); int ...
随机推荐
- 解决跨域问题-jsonp&cors
跨域的原因 浏览器的同源策略 同源策略是浏览器上为安全性考虑实施的非常重要的安全策略. 指的是从一个域上加载的脚本不允许访问另外一个域的文档属性. 举个例子:比如一个恶意网站的页面通过iframe嵌入 ...
- JAVA基础——集合——HashMap
HashMap集合: 常用方法(JDK1.8): 从此映射中移除所有映射关系(元素): public void clear() 返回此 HashMap 实例的浅表副本:并不复制键和值本身: p ...
- pwn学习日记Day4 基础知识积累
知识杂项 *:字符串重复 空指令NOP:\x90 cmp:是比较指令,cmp的功能相当于减法指令.它不保存结果,只是影响相应的标志位. xor:将两个操作数进行异或运算,并将结果存放到操作数1中. s ...
- Qt 的坐标系统
QWidget *q = , Qt::WindowStaysOnTopHint); q->setWindowTitle(QObject::tr("父窗口widget")); ...
- linux 创建用户和添加到组
1.添加用户 先用root用户登录 useradd -m testuser #这样的做会在/home下创建目录 2.指定shell #cat /etc/passwd #查看用户指定shell roo ...
- 擦他丫的,今天在Django项目中引用静态文件jQuery.js 就是引入报错,终于找到原因了!
擦 ,今天在Django项目中引用静态文件jQuery.js 就是引入报错,终于找到原因了! 问题在于我使用的谷歌浏览器,默认使用了缓存,导致每次访问同一个url时,都返回的是缓存里面的东西.通过谷歌 ...
- nginx根据CPU配置多线程运行
转自:Nginx使用教程(二):Nginx配置性能优化之worker配置 配置Nginx workers <br\>NGINX根据指定的配置运行固定数量的工作进程. 这些工作进程负责处理所 ...
- 1*1的卷积核与Inception
https://www.zhihu.com/question/56024942 https://blog.csdn.net/a1154761720/article/details/53411365 本 ...
- 自定义Markdown例子
主题1 正文字体 粗体 正文行内代码 斜体 int a = 2 /*代码块*/ /*杨韬的学习备忘录*/ private void CheckCloseFigure() { if (needClose ...
- phpstorm 安装yaf代码提示文件
安装yaf代码提示:https://www.jianshu.com/p/dc719ae74f97 4.下载代码提示文件 下载地址: https://github.com/xudianyang/yaf. ...