博客
关于我
PAT——1040. 有几个PAT
阅读量:463 次
发布时间:2019-03-06

本文共 1275 字,大约阅读时间需要 4 分钟。

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

现给定字符串,问一共可以形成多少个PAT?

输入格式:

输入只有一行,包含一个字符串,长度不超过105,只包含P、A、T三种字母。

输出格式:

在一行中输出给定字符串中包含多少个PAT。由于结果可能比较大,只输出对1000000007取余数的结果。

输入样例:

APPAPT

输出样例:

2
1 package com.hone.basical; 2  3 import java.util.Scanner; 4  5 /** 6  * 原题目:https://www.patest.cn/contests/pat-b-practise/1039 7  *  8  * @author Xia 理解题目 9  * 有两个结点运行超时10  * 思路来源:https://www.cnblogs.com/asinlzm/p/4440603.html11  */12 13 public class basicalLevel1040howManyPat {14     public static void main(String[] args) {15         Scanner in = new Scanner(System.in);16         char[] pat = in.nextLine().toCharArray();17         int len = pat.length;18         in.close();19         int numPat = 0, numAt = 0, num = 0;20         // 从后面往前面遍历21         while ((len--) > 0) {22             if (pat[len] == 'T') {23                 numAt++;24             } else if (pat[len] == 'A') {25                 numPat += numAt;26             } else {27                 num += numPat;28                 // 因为输出的结果具有周期性,所以可以提前处理,当参数大于指定的次数的时候29                 // 可以先取余数30                 if (num > 1000000007) {31                     num = num % 1000000007;32                 }33             }34         }35         System.out.println(num);36     }37 }

 

你可能感兴趣的文章
mysql添加用户权限报1064 - You have an error in your SQL syntax问题解决
查看>>
mysql添加索引
查看>>
mysql添加表注释、字段注释、查看与修改注释
查看>>
mysql源码安装
查看>>
Mysql源码安装过程中可能碰到的问题
查看>>
MySQL灵魂16问,你能撑到第几问?
查看>>
MySQL灵魂拷问:36题带你面试通关
查看>>
mysql状态分析之show global status
查看>>
mysql状态查看 QPS/TPS/缓存命中率查看
查看>>
mysql生成树形数据_mysql 实现树形的遍历
查看>>
mysql用于检索的关键字_Mysql全文搜索match...against的用法
查看>>
MySQL用得好好的,为什么要转ES?
查看>>
MySql用户以及权限的管理。
查看>>
MySQL用户权限配置:精细控制和远程访问的艺术!------文章最后有惊喜哦。
查看>>
mysql用户管理、常用语句、数据分备份恢复
查看>>
MySQL留疑问:left join时选on还是where?
查看>>
mysql登陆慢问题解决
查看>>
MySQL的 DDL和DML和DQL的基本语法
查看>>
mysql的 if else , case when then, IFNULL
查看>>
MySQL的10种常用数据类型
查看>>