码迷,mamicode.com
首页 > 其他好文 > 详细

ABC122C - GeT AC 题解

时间:2020-01-20 22:51:40      阅读:105      评论:0      收藏:0      [点我收藏+]

标签:efi   ==   inline   题解   使用   abc   names   mes   bit   

首先可以确定的是,既然 \(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 题解

标签:efi   ==   inline   题解   使用   abc   names   mes   bit   

原文地址:https://www.cnblogs.com/Xray-luogu/p/12219508.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!