1040. 有几个PAT(25)
原题: https://www.patest.cn/contests/pat-b-practise/1040
思路: 先给大家扔个测试PAPAATTPATTT, 人工查一下这段字符串能组成
34个PAT.
这一题我自己的想法非常的渣, 也非常复杂, 最后看了OliverLew大神的解答,
才明白这题原来是这样搞的. 本题的解法非常类似"在线处理"的思想.
观察下面3段字符串
- PA (只能组成1个PA)
- PAPA (第一个A能组成1个PA, 第2个A能组成2个PA, 一共1+2=3个PA)
- PAPAPA (1 + 2 + 3 = 6个PA)
现在我们看一下PAPAATTPATTT这个字符串, 我们不要一开始就盯着PAT这
3个字符, 而是先看字符串里有多少P, 再看有多少PA, 最后确定有多少PAT.
从左到右一个一个字符的看, 下面我给字符串标上号
PAPAATTPAT T T
0123456789 10 11 - 走到下标0, P=1, PA=0, PAT=0
- 走到下标1, P=1, PA=1, PAT=0
- 走到下标2, P=2, PA=1, PAT=0
- 走到下标3, P=2, PA=1+2=3, PAT=0
- 走到下标4, P=2, PA=3+2=5, PAT=0
- 走到下标5, P=2, PA=5, PAT=5
- 走到下标6, P=2, PA=5, PAT=5+5=10
- 走到下标7, P=3, PA=5, PAT=10
- 走到下标8, P=3, PA=5+3=8, PAT=10
- 走到下标9, P=3, PA=8, PAT=10+8=18
- 走到下标10, P=3, PA=8, PAT=18+8=24
- 走到下标0, P=3, PA=8, PAT=24+8=34
相信大家已经看明白, 是的就这么简单, 寥寥10几行搞定, 我一开始自己搞了
6个多小时, 代码一百多行, 还是不能全对, 思想太重要了.
注意取余数是在中间过程就取, 不用等到最后总数再取余.
完整实现:
#include <stdio.h>
#define MOD 1000000007
int main (void) {
long int p = 0;
long int pa = 0;
long int pat = 0;
char ch;
while ((ch = getchar()) != '\n') {
if (ch == 'P') p++;
if (ch == 'A') pa = (pa + p) % MOD;
if (ch == 'T') pat = (pat + pa) % MOD;
}
printf("%ld", pat);
return 0;
}
参考资料:
OliverLew的简书: http://www.jianshu.com/p/65291de1906b
1040. 有几个PAT(25)的更多相关文章
- 1040 有几个PAT (25 分)
题目:1040 有几个PAT (25 分) 思路: 是个规律题,只要找到规律就有思路,那代码基本就有了,就是怎么实现比较好和是否简洁的问题. 很明显:A是分水岭,A前面有多少个P和A后面有多少个T知道 ...
- PAT Basic 1040 有几个PAT (25 分)
字符串 APPAPT 中包含了两个单词 PAT,其中第一个 PAT 是第 2 位(P),第 4 位(A),第 6 位(T):第二个 PAT 是第 3 位(P),第 4 位(A),第 6 位(T). 现 ...
- 1040 有几个PAT (25 分)C语言
字符串 APPAPT 中包含了两个单词 PAT,其中第一个 PAT 是第 2 位§,第 4 位(A),第 6 位(T):第二个 PAT 是第 3 位§,第 4 位(A),第 6 位(T). 现给定字符 ...
- PAT 1040有几个PAT
原题:https://pintia.cn/problem-sets/994805260223102976/problems/994805282389999616 1040 有几个PAT (25 分) ...
- PAT(B) 1040 有几个PAT(Java)
题目链接:1040 有几个PAT (25 point(s)) 题目描述 字符串 APPAPT 中包含了两个单词 PAT,其中第一个 PAT 是第 2 位§,第 4 位(A),第 6 位(T):第二个 ...
- PAT乙级1040 有几个PAT
题目: 1040 有几个PAT (25分) 字符串 APPAPT 中包含了两个单词 PAT,其中第一个 PAT 是第 2 位(P),第 4 位(A),第 6 位(T):第二个 PAT 是第 3 位 ...
- PAT-乙级-1040. 有几个PAT(25)
1040. 有几个PAT(25) 时间限制 120 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 字符串APPAPT中包含了两个单 ...
- PAT (Basic Level) Practise (中文)-1040. 有几个PAT(25)
1040. 有几个PAT(25) http://www.patest.cn/contests/pat-b-practise/1040 字符串APPAPT中包含了两个单词“PAT”,其中第一个P ...
- 1040 有几个PAT (25 分)
题目链接:1040 有几个PAT (25 分) 做这道题目,遇到了新的困难.解决之后有了新的收获,甚是欣喜! 刚开始我用三个vector数组存储P A T三个字符出现的位置,然后三层for循环,根据字 ...
- PAT-B 1040. 有几个PAT(25)
1040. 有几个PAT(25) 时间限制 120 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 字符串APPAPT中包含了两个单 ...
随机推荐
- POJ 3093 Margaritas(Kind of wine) on the River Walk (背包方案统计)
题目 Description One of the more popular activities in San Antonio is to enjoy margaritas in the park ...
- 安装php5.5 mssql扩展报错
./configure 后,直接make可能会出现libtool: link: `php_mssql.lo' is not a valid libtool object 的错误. make clean ...
- Python 文件类型
Python的文件类型分为以下几种: 1. 源代码文件,也就是以 .py 为扩展名的文件,由 python 程序解释,不需要编译 2. 字节代码文件,python 源代码文件经过编译后生成的扩展名为 ...
- JavaScript作用域原理——预编译
JavaScript是一种脚本语言, 它的执行过程, 是一种翻译执行的过程.并且JavaScript是有预编译过程的,在执行每一段脚本代码之前, 都会首先处理var关键字和function定义式(函数 ...
- mySQL数据库二:命令行的使用
在做整理的时候,上一篇刚开始只是简单的做了个数据类型的开头,在这里简单说一下mySQL的使用以及它的命令行 1.准备工作 有一个好的开发工具可以几何倍数的增加我们的工作效率,所以,工具是必不可少的,首 ...
- Mybatis中的foreach
<delete id="deleteByParam"> DELETE FROM YZ_SECURITIES_CURRENCY WHERE ID IN <forea ...
- iOS-利用插件实时刷新模拟器(提高效率)
解决办法: 1.需要给Xcode安装一个Alcatraz插件 安装完成后:点击window 下面的 package manager 安装我们今天的主角 2. ‘Injection Plugin for ...
- PHP中str_replace和substr_replace有什么区别?
两个函数的定义:(1)str_replace() 函数替换字符串中的一些字符(区分大小写). 该函数必须遵循下列规则: 如果搜索的字符串是一个数组,那么它将返回一个数组. 如果搜索的字符串是一个数组, ...
- nodeJS基础---->nodeJS的使用(一)
Node.js是一个Javascript运行环境(runtime).实际上它是对Google V8引擎进行了封装.V8引擎执行Javascript的速度非常快,性能非常好.Node.js对一些特殊用例 ...
- HTTP/2笔记之连接建立
前言 HTTP/2协议在TCP连接之初进行协商通信,只有协商成功,才会涉及到后续的请求-响应等具体的业务型数据交换. HTTP版本标识符 h2,基于TLS之上构建的HTTP/2,作为ALPN的标识符, ...