1003. 我要通过!(20) (ZJUPAT 模拟)
题目链接:http://pat.zju.edu.cn/contests/pat-b-practise/1003
“答案正确”是自己主动判题系统给出的最令人欢喜的回复。本题属于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
思路:
P之前A的数目乘以P与T之间A的数目等于P后面A的数目。
对于第1个规则:0*0=0。
对于第2个规则:x*1=x。
对于第3个规则:aPbTc假设正确,那么b一定是A、a=c,bA就是AA,a*2=aa=ca。
代码例如以下:
- #include <cstdio>
- #include <cstring>
- #include <algorithm>
- #include <iostream>
- #include <string>
- using namespace std;
- int Judge(string s)
- {
- //推断是否是仅仅由P、A、T三种字母组成
- for(int i = 0; i < s.size(); i++)
- {
- if(s[i]!='P' && s[i]!='A' && s[i]!='T')
- {
- return 1;
- }
- }
- return 0;
- }
int main()
{
string s;
int t;
scanf("%d",&t);
while(t--)
{
cin >> s;
int flag = Judge(s);
if(flag)
{
printf("NO\n");
continue;
}
int contP = 0, contT = 0;
int posP = 0, posT = 0;
for(int i = 0; i < s.size(); i++)
{
//检验P、T的个数及位置
if(s[i] == 'P')
{
contP++;
posP = i;
}
else if(s[i] == 'T')
{
contT++;
posT = i;
}
}
if(contP!=1 || contT!=1)
{
//P、T的个数不止一个就错误
printf("NO\n");
continue;
}
else if(posT-posP < 2)
{
//p、T之间没有其它字母(A)则错误
printf("NO\n");
continue;
}
int i = 0;//P左边A的个数乘以中间的等于T右边的个数
int cleft = 0, cmid = 0, cright = 0;
for(i = 0; i < s.size(); i++)
{
if(s[i] == 'P')
break;
else if(s[i] == 'A')
cleft++;
}
for(; i < s.size(); i++)
{
if(s[i] == 'T')
break;
else if(s[i] == 'A')
cmid++;
}
for(; i < s.size(); i++)
{
if(s[i] == 'A')
cright++;
}
if(cleft *
1003. 我要通过!(20) (ZJUPAT 模拟)的更多相关文章
- 牛客网 PAT 算法历年真题 1003: 数素数 (20)
1003:数素数 (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 令Pi表示第i个素数.现任给两个正整 ...
- 9.20 noip模拟试题
Problem 1 双色球(ball.cpp/c/pas) [题目描述] 机房来了新一届的学弟学妹,邪恶的chenzeyu97发现一位学弟与他同名,于是他当起了善良的学长233 “来来来,学弟,我 ...
- 2018.10.20 NOIP模拟 蛋糕(线段树+贪心/lis)
传送门 听说是最长反链衍生出的对偶定理就能秒了. 本蒟蒻直接用线段树模拟维护的. 对于第一维排序. 维护第二维的偏序关系可以借助线段树/树状数组维护逆序对的思想建立权值线段树贪心求解. 代码
- FJoi2017 1月20日模拟赛 直线斯坦纳树(暴力+最小生成树+骗分+人工构造+随机乱搞)
[题目描述] 给定二维平面上n个整点,求该图的一个直线斯坦纳树,使得树的边长度总和尽量小. 直线斯坦纳树:使所有给定的点连通的树,所有边必须平行于坐标轴,允许在给定点外增加额外的中间节点. 如下图所示 ...
- FJoi2017 1月20日模拟赛 交错和(等差数列+rmq)
[题目描述] 无限循环数字串S由长度为n的循环节s构成.设s为12345(n=5),则数字串S为123451234512345… 设Si为S的第i位数字,在上面的例子中,S1=1,S2=2,S6=1. ...
- FJoi2017 1月20日模拟赛 恐狼后卫(口糊动规)
Problem 1 恐狼后卫(wolf.cpp/c/pas) [题目描述] 著名卡牌游戏<石炉传说>中有一张随从牌:恐狼后卫.恐狼后卫的能力是使得相邻随从的攻击力提高. 现在有n张恐狼后卫 ...
- 1069. The Black Hole of Numbers (20)【模拟】——PAT (Advanced Level) Practise
题目信息 1069. The Black Hole of Numbers (20) 时间限制100 ms 内存限制65536 kB 代码长度限制16000 B For any 4-digit inte ...
- 【2019.8.20 NOIP模拟赛 T3】小X的图(history)(可持久化并查集)
可持久化并查集 显然是可持久化并查集裸题吧... 就是题面长得有点恶心,被闪指导狂喷. 对于\(K\)操作,直接\(O(1)\)赋值修改. 对于\(R\)操作,并查集上直接连边. 对于\(T\)操作, ...
- 【2019.7.20 NOIP模拟赛 T1】A(A)(暴搜)
打表+暴搜 这道题目,显然是需要打表的,不过打表的方式可以有很多. 我是打了两个表,分别表示每个数字所需的火柴棒根数以及从一个数字到另一个数字,除了需要去除或加入的火柴棒外,至少需要几根火柴棒. 然后 ...
随机推荐
- Google TPU 揭密——看TPU的架构框图,矩阵加乘、Pool等处理模块,CISC指令集,必然需要编译器
Google TPU 揭密 转自:https://mp.weixin.qq.com/s/Kf_L4u7JRxJ8kF3Pi8M5iw Google TPU(Tensor Processing Unit ...
- Dungeon Master hdoj
Dungeon Master Time Limit : 2000/1000ms (Java/Other) Memory Limit : 131072/65536K (Java/Other) Tot ...
- 【POJ 3700】 Missile Defence System
[题目链接] http://poj.org/problem?id=3700 [算法] 对于每一枚导弹,有4种决策 : 1.新建一套递增的系统拦截它 2.新建一套递减的系统拦截它 3.在已经建好的递增拦 ...
- k8s istio 配置请求的路由规则
使用istio我们可以根据权重和HTTP headers来动态配置请求路由. 基于内容的路由 因为BookInfo示例部署了3个版本的评论微服务,我们需要设置一个默认路由. 否则,当你多次访问应用程序 ...
- [jqpolt] formatString 日期格式化列表
// 年 %Y 2008 %y 08 // 月 %m 09 %#m 9 %B September %b Sep // 日 %d 05 %#d 5 %e 5 %A ...
- (转)50 个 jQuery 小技巧
1. 如何修改jQuery默认编码(例如默认UTF-8改成改GB2312): $.ajaxSetup({ajaxSettings:{ contentType:"application/x-w ...
- Angular 通过constant(name,value),value(name,value)创建服务
区别: constant()可以将已经存在的变量值注册为服务,并将其注入到应用的其他部分中,他的value可以是值,也可以是对象.通过他来配置数据,也就是说可以在config里注入,但是他是不可以修改 ...
- python tips:类与实例的属性问题
实例是具象化的类,它可以作为类访问所有静态绑定到类上的属性,包括类变量与方法,也可以作为实例访问动态绑定到实例上的属性. 实例1: class A: work = list("hello&q ...
- java 常用API 包装 数据转换
package com.oracel.demo01; public class Sjzh { // 将基本数据类型转字符串 public static void main(String[] args) ...
- JS 100元购物卡,牙刷5元,香皂2元、洗发水15元 100元正好花完有多少种可能
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...