鱼C论坛

 找回密码
 立即注册
查看: 1949|回复: 10

[已解决]梦想星际舰队第18关 && FCOI #8 第五题QAQ题解【原创】

[复制链接]
发表于 2023-8-23 18:05:04 | 显示全部楼层 |阅读模式

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

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

x


梦想星际舰队第18关 && FCOI #8 题解


第五题:QAQ

题目描述
给定由 A, Q 组成的字符串 S,你要统计三元组 (i,j,k) 的个数,满足 1≤i<j<k≤|S|,Si= Q, Sj= A, Sk= Q。

其实上就是要求 S 里面有多少子串为 QAQ。

本题使用多测,一共有 T 个测试用例。

输入格式
第一行一个整数 T。

接下来 T 行,每行一个字符串 S,表示一个测试用例。

输出格式
T 行,每行一个整数表示对应测试用例的答案。

输入输出样例
输入 #1
  1. 6
  2. QAQQ
  3. QAAQQ
  4. QQQ
  5. QQAQAAQ
  6. AAAQQQAAAQQQAAA
  7. QQAQAQAQAQAAAQAAQAQAQAQAQAAAQAQQAQ
复制代码

输出 #1
  1. 2
  2. 4
  3. 0
  4. 10
  5. 27
  6. 916
复制代码


数据范围

对于 100% 的数据,保证 3≤|S|≤5000,1≤T≤1000,S 仅包含 A, Q 两个字符。

其他说明
本题目为 zhangjinxuan 原创题目。
测试链接:https://www.luogu.com.cn/problem/U325168

答案与解析
游客,如果您要查看本帖隐藏内容请回复
[/hide]

最佳战士排行榜
游客,如果您要查看本帖隐藏内容请回复
[/hide]
最佳答案
2023-8-23 20:21:33
  1. #include <bits/stdc++.h>
  2. using namespace std;

  3. int t, n, Q[5001], QA[5001], QAQ[5001];
  4. string s;

  5. int main() {
  6.     cin >> t;
  7.     while (t--) {
  8.         cin >> s;
  9.         memset(Q, 0, sizeof(Q));
  10.         memset(QA, 0, sizeof(QA));
  11.         memset(QAQ, 0, sizeof(QAQ));
  12.         for (int i = 0; i < s.size(); i++) {
  13.             Q[i] = Q[i - 1], QA[i] = QA[i - 1], QAQ[i] = QAQ[i - 1];
  14.             if (s[i] == 'Q') Q[i]++, QAQ[i] += QA[i - 1], QAQ[i] %= (long long)1e9 + 7;
  15.             else QA[i] += Q[i - 1], QA[i] %= (long long)1e9 + 7;
  16.         }
  17.         cout << QAQ[s.size() - 1] << endl;
  18.     }

  19.     return 0;
  20. }
复制代码


借鉴一下代码

本帖被以下淘专辑推荐:

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

使用道具 举报

 楼主| 发表于 2023-8-23 18:05:38 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-8-23 18:34:53 | 显示全部楼层

你觉得呢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-8-23 19:30:21 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-14 02:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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