zoukankan      html  css  js  c++  java
  • 牛客OI周赛6-提高组 B 践踏

    践踏

    思路:

    如果k不为0, 那么就是对k取模意义下的区间更新, 单点查询

    否则, 就是普通的区间更新, 单点查询

    代码:

    #pragma GCC optimize(2)
    #pragma GCC optimize(3)
    #pragma GCC optimize(4)
    #include<bits/stdc++.h>
    using namespace std;
    #define fi first
    #define se second
    #define pi acos(-1.0)
    #define LL long long
    //#define mp make_pair
    #define pb push_back
    #define ls rt<<1, l, m
    #define rs rt<<1|1, m+1, r
    #define ULL unsigned LL
    #define pll pair<LL, LL>
    #define pli pair<LL, int>
    #define pii pair<int, int>
    #define piii pair<pii, int>
    #define mem(a, b) memset(a, b, sizeof(a))
    #define fio ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
    #define fopen freopen("in.txt", "r", stdin);freopen("out.txt", "w", stout);
    //head
    
    const int N = 2e4 + 10;
    int bit[N], up;
    vector<int> vc;
    piii a[N];
    void add(int x, int a) {
        while(x <= up) bit[x] += a, x += x&-x;
    }
    int sum(int x) {
        int res = 0;
        while(x) res += bit[x], x -= x&-x;
        return res;
    }
    int main() {
        int n, k, op, l, r;
        scanf("%d %d", &n, &k);
        if(n == 0) return 0*puts("fafa");
        if(k) {
            up = k;
            for (int i = 1; i <= n; i++) {
                scanf("%d %d", &op, &l);
                if(op == 1) {
                    scanf("%d", &r);
                    if(r - l + 1 >= k) {
                        add(1, 1), add(k+1, -1);
                        continue;
                    }
                    (l %= k) += 1;
                    (r %= k) += 1;
                    if(l <= r) add(l, 1), add(r+1, -1);
                    else add(1, 1), add(r+1, -1), add(l, 1), add(k+1, -1);
                }
                else if(op == 2) {
                    scanf("%d", &r);
                    if(r - l + 1 >= k) {
                        add(1, -1), add(k+1, 1);
                        continue;
                    }
                    (l %= k) += 1;
                    (r %= k) += 1;
                    if(l <= r) add(l, -1), add(r+1, 1);
                    else add(1, -1), add(r+1, 1), add(l, -1), add(k+1, 1);
                }
                else {
                    printf("%d
    ", sum(l%k + 1));
                }
            }
        }
        else {
            up = 2*n;
            for (int i = 1; i <= n; i++) {
                scanf("%d %d", &a[i].se, &a[i].fi.fi);
                vc.pb(a[i].fi.fi);
                if(a[i].se <= 2) {
                    scanf("%d", &a[i].fi.se);
                    vc.pb(a[i].fi.se);
                }
            }
            sort(vc.begin(), vc.end());
            vc.erase(unique(vc.begin(), vc.end()), vc.end());
            for (int i = 1; i <= n; i++) {
                if(a[i].se == 1) {
                    l = lower_bound(vc.begin(), vc.end(), a[i].fi.fi) - vc.begin() + 1;
                    r = lower_bound(vc.begin(), vc.end(), a[i].fi.se) - vc.begin() + 1;
                    add(l, 1);
                    add(r+1, -1);
                }
                else if(a[i].se == 2) {
                    l = lower_bound(vc.begin(), vc.end(), a[i].fi.fi) - vc.begin() + 1;
                    r = lower_bound(vc.begin(), vc.end(), a[i].fi.se) - vc.begin() + 1;
                    add(l, -1);
                    add(r+1, 1);
                }
                else {
                    int x = lower_bound(vc.begin(), vc.end(), a[i].fi.fi) - vc.begin() + 1;
                    printf("%d
    ", sum(x));
                }
            }
        }
        return 0;
    }
  • 相关阅读:
    chrony时间同步工具
    SyntaxError: missing ; before statement
    SQL 获得两个时间段之间的数据
    EasyUI DataGrid 获得分页信息
    c#里如何实现讲一个字符串数组例如 “112,221”转化成两个字符串数组“112” “221” 中间以逗号隔开
    SQL 将一个表中的所有记录插入到一个临时表中
    SQL查找指定行的记录
    SQL 中的Begin...End语句
    SQL将完整时间字段截取到年月日
    Linux学习之三:档案与文件系统的压缩与打包
  • 原文地址:https://www.cnblogs.com/widsom/p/9990384.html
Copyright © 2011-2022 走看看