zoukankan      html  css  js  c++  java
  • ABC122C

    首先可以确定的是,既然 (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;
    }
    
  • 相关阅读:
    js操作
    函数知识点补充
    css---position
    css-浮动
    css-边界重叠以及边界塌陷
    css
    css文本类型操作
    POJ 2828 线段树活用
    POJ 3468 线段树
    POJ 3013 SPFA算法,邻接表的使用
  • 原文地址:https://www.cnblogs.com/Xray-luogu/p/12219508.html
Copyright © 2011-2022 走看看