鱼C论坛

 找回密码
 立即注册
查看: 2524|回复: 0

[技术交流] PTA A_1093 Count PAT's

[复制链接]
发表于 2020-1-29 12:50:13 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目链接:https://pintia.cn/problem-sets/994805342720868352/problems/994805373582557184

解:递推法
  1. #include <stdio.h>
  2. #include <string.h>

  3. typedef long long int LL;

  4. char str[100010];
  5. int P_num[100010];
  6. int T_num[100010];

  7. int main(void)
  8. {
  9.         int i, len;
  10.         LL count = 0;
  11.         
  12.         gets(str);
  13.         
  14.         len = strlen(str);
  15.         
  16.         P_num[0] = (str[0] == 'P') ? 1 : 0;
  17.         T_num[len - 1] = (str[len - 1] == 'T') ? 1 : 0;
  18.         
  19.         for (i = 1; i < len; i++)
  20.                 P_num[i] = (str[i] == 'P') ? (P_num[i - 1] + 1) : P_num[i - 1];

  21.         for (i = len - 2; i >= 0; i--)
  22.                 T_num[i] = (str[i] == 'T') ? (T_num[i + 1] + 1) : T_num[i + 1];

  23.         for (i = 0; i < len; i++)
  24.                 if (str[i] == 'A')
  25.                         count += (LL)P_num[i] * (LL)T_num[i];

  26.         printf("%d", count % 1000000007);
  27.         
  28.         return 0;
  29. }
复制代码



小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-1 15:58

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表