原题: 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)的更多相关文章

  1. 1040 有几个PAT (25 分)

    题目:1040 有几个PAT (25 分) 思路: 是个规律题,只要找到规律就有思路,那代码基本就有了,就是怎么实现比较好和是否简洁的问题. 很明显:A是分水岭,A前面有多少个P和A后面有多少个T知道 ...

  2. PAT Basic 1040 有几个PAT (25 分)

    字符串 APPAPT 中包含了两个单词 PAT,其中第一个 PAT 是第 2 位(P),第 4 位(A),第 6 位(T):第二个 PAT 是第 3 位(P),第 4 位(A),第 6 位(T). 现 ...

  3. 1040 有几个PAT (25 分)C语言

    字符串 APPAPT 中包含了两个单词 PAT,其中第一个 PAT 是第 2 位§,第 4 位(A),第 6 位(T):第二个 PAT 是第 3 位§,第 4 位(A),第 6 位(T). 现给定字符 ...

  4. PAT 1040有几个PAT

    原题:https://pintia.cn/problem-sets/994805260223102976/problems/994805282389999616 1040 有几个PAT (25 分) ...

  5. PAT(B) 1040 有几个PAT(Java)

    题目链接:1040 有几个PAT (25 point(s)) 题目描述 字符串 APPAPT 中包含了两个单词 PAT,其中第一个 PAT 是第 2 位§,第 4 位(A),第 6 位(T):第二个 ...

  6. PAT乙级1040 有几个PAT

    题目: 1040 有几个PAT (25分)   字符串 APPAPT 中包含了两个单词 PAT,其中第一个 PAT 是第 2 位(P),第 4 位(A),第 6 位(T):第二个 PAT 是第 3 位 ...

  7. PAT-乙级-1040. 有几个PAT(25)

    1040. 有几个PAT(25) 时间限制 120 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 字符串APPAPT中包含了两个单 ...

  8. PAT (Basic Level) Practise (中文)-1040. 有几个PAT(25)

    1040. 有几个PAT(25)     http://www.patest.cn/contests/pat-b-practise/1040 字符串APPAPT中包含了两个单词“PAT”,其中第一个P ...

  9. 1040 有几个PAT (25 分)

    题目链接:1040 有几个PAT (25 分) 做这道题目,遇到了新的困难.解决之后有了新的收获,甚是欣喜! 刚开始我用三个vector数组存储P A T三个字符出现的位置,然后三层for循环,根据字 ...

  10. PAT-B 1040. 有几个PAT(25)

    1040. 有几个PAT(25) 时间限制 120 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 字符串APPAPT中包含了两个单 ...

随机推荐

  1. linux Redhat 6环境上通过源码包安装DRBD 8

    环境描述: 操作系统版本:Red Hat Enterprise Linux Server release 6.6 (Santiago) 系统内核版本:2.6.32-504.el6.x86_64 DRB ...

  2. CSS3 transform 引起z-index失效

    https://my.oschina.net/u/2941696/blog/1529373

  3. [转]ASP.NET MVC 5 - 查询Details和Delete方法

    在这部分教程中,接下来我们将讨论自动生成的Details和Delete方法. 查询Details和Delete方法 打开Movie控制器并查看Details方法. public ActionResul ...

  4. 如何:为 IIS 7.0 配置 <system.webServer> 节

    https://technet.microsoft.com/zh-cn/sysinternals/bb763179.aspx https://www.cnblogs.com/tl2f/p/501615 ...

  5. 超全面的JavaWeb笔记day07<Java基础加强>

    1.myeclipse安装和使用(**) 2.debug调试模式(**) - F6: 单步执行 - F8:结束断点,后面有断点到下一个断点 3.myeclipse快捷键(**) 4.junit单元测试 ...

  6. day05<Java语言基础--数组>

    Java语言基础(数组概述和定义格式说明) Java语言基础(数组的初始化动态初始化) Java语言基础(Java中的内存分配以及栈和堆的区别) Java语言基础(数组的内存图解1一个数组) Java ...

  7. POJ 1141 Brackets Sequence(区间DP, DP打印路径)

    Description We give the following inductive definition of a “regular brackets” sequence: the empty s ...

  8. .Net WebAPI文档自动化

    1.在VS2015中右键选择工程: 2.点击NuGet程序包: 3.输入Swagger在线搜索: 4.安装:Swagger.Net.UI和Swashbuckle包: 5.打开SwaggerNet.cs ...

  9. strip() 、lstrip() 、rstrip()

    strip() 用于移除字符串开头和结尾的空格或换行符,如果指定参数,则表示移除指定的字符lstrip() 用于移除字符串开头的空格或换行符,如果指定参数,则表示移除指定的字符rstrip() 用于移 ...

  10. C语言100个经典的算法之兔子总数计算内含printf的用法

    语言的学习基础,100个经典的算法 C语言的学习要从基础开始,这里是100个经典的算法-1C语言的学习要从基础开始,这里是100个经典的算法 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一 ...