ABC122C - GeT AC 题解

Posted xray-luogu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ABC122C - GeT AC 题解相关的知识,希望对你有一定的参考价值。

首先可以确定的是,既然 (N) 已经到了 (10^5) 的范围,并且还有个同样范围的 (Q),显然不能用 (O(NQ)) 的大暴力.
如何优化呢?遂盯着题目看,发现这道题的本质就是一个前缀和.
然后...就不用说了.
哦对了,唯一的坑点:查询时不能用 (sum_y-sum_{x-1}),而需要使用 (sum_y-sum_x).原因请读者自己探究.

Code((n) 年前的代码了...):

# include <bits/stdc++.h>
using namespace std;
# define maxN 100005
char s[maxN];
int N, Q, sum[maxN];
int main() {
    cin >> N >> Q >> s + 1;
    for(int i = 1; i <= N; ++i) {
        sum[i] = sum[i - 1];
        if(s[i] == 'C' && s[i - 1] == 'A') ++sum[i];
    }
    while(Q--) {
        int x, y; cin >> x >> y;
        cout << sum[y] - sum[x] << endl;
    }
    return 0;
}

以上是关于ABC122C - GeT AC 题解的主要内容,如果未能解决你的问题,请参考以下文章

HDU3247 Resource Archiver(AC自动机+BFS+DP)

[ARC122C] Calculator

leetcode剑指offer合集+题解

leetcode剑指offer合集+题解

Educational Codeforces Round 50 (Rated for Div. 2)的ABC三题AC代码

2018省赛赛第一次训练题解和ac代码