GYM 100741A Queries

Posted 小时のblog

tags:

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

传送门

题目大意:

一个长度为n的序列,q次三种操作

+p  r:下标为p的数+r

-p r:下标为p的数-r

s l r mod [L,R]中有多少数%m=mod,m已经给出

题解:

开十个树状数组

代码

我的

#include<iostream>
#include<cstdio>
using namespace std;

int n,m,q,l,r,od,p,mod,a[100];
struct Tree{
    int tre[1001];
}s[10];

int lowbit(int x){
    return x&(-x);
}

void add(int k,int p){
    while(p<=n){
        s[k].tre[p]++;
        p+=lowbit(p);
    }
}

void modify(int k,int p,int x){
    while(p<=n){
        s[k].tre[p]+=x;
        p+=lowbit(x);
    }
}

int sum(int l,int r,int mod){
    int cntl=0,cntr=0;l--;
    while(l){
        cntl+=s[mod].tre[l];
        l-=lowbit(l);
    }
    while(r){
        cntr+=s[mod].tre[r];
        r-=lowbit(r);
    }
    return cntr-cntl;
} 

int main(){
    scanf("%d%d%d",&n,&m,&q);
    for(int i=1;i<=n;i++){
        scanf("%d",&a[i]);
        add(a[i]%m,i);
    }
    for(int i=1;i<=q;i++){
        scanf("%d",&od);
        if(od==1){
            scanf("%d%d",&p,&r);
            modify(a[p]%m,p,-1);
            a[p]+=r;
            modify(a[p]%m,p,1);
        }
        if(od==2){
            scanf("%d%d",&p,&r);
            modify(a[p]%m,p,-1);
            a[p]-=r;
            modify(a[p]%m,p,1);
        }
        if(od==3){
            scanf("%d%d%d",&l,&r,&mod);
            printf("%d\n",sum(l,r,mod));
        }
    }
    return 0;
}

丁神的

#include<bits/stdc++.h>
#define N 10010
#define ll long long
using namespace std;

struct BIT {
    ll c[N];
    int n;

    int lowbit(int x) {
        return x&(-x);
    }
    void modify(int x,ll y) {
        for(; x<=n; x+=lowbit(x)) c[x]+=y;
    }
    ll query(int x) {
        ll ret=0;
        for(; x; x-=lowbit(x)) ret+=c[x];
        return ret;
    }

    ll query(int l,int r) {
        return query(r)-query(l-1);
    }
} bit[20];

int n,m,T;
ll a[N];

int main() {
    scanf("%d%d",&n,&m);
    for(int i=0; i<m; i++) bit[i].n=n;
    for(int i=1; i<=n; i++) {
        scanf("%lld",&a[i]);
        bit[a[i]%m].modify(i,a[i]);
    }
    scanf("%d",&T);
    while(T--) {
        int x,y,z;
        char opt[10];
        scanf("%s%d%d",opt,&x,&y);
        if(opt[0]==+) {
            bit[a[x]%m].modify(x,-a[x]);
            a[x]+=y;
            bit[a[x]%m].modify(x,a[x]);
            printf("%lld\n",a[x]);
        }
        if(opt[0]==-) {
            if(a[x]<y) {
                printf("%lld\n",a[x]);
            } else {
                bit[a[x]%m].modify(x,-a[x]);
                a[x]-=y;
                bit[a[x]%m].modify(x,a[x]);
                printf("%lld\n",a[x]);
            }
        }
        if(opt[0]==s) {
            scanf("%d",&z);
            printf("%lld\n",bit[z].query(x,y));
        }
    }
    return 0;
}

 

以上是关于GYM 100741A Queries的主要内容,如果未能解决你的问题,请参考以下文章

Codeforces Gym 101138 D. Strange Queries

gym101964 G.Matrix Queries(思维+线段树)

Gym101138D Strange Queries 莫队前缀和容斥

gym101964G Matrix Queries seerc2018g题 数学归纳法+线段树(递归)

Gym 101102J---Divisible Numbers(反推技巧题)

强化学习笔记:Gym入门--从安装到第一个完整的代码示例