zoukankan      html  css  js  c++  java
  • LG2709 小B的询问

    莫队算法模板题

    #include<iostream>
    #include<algorithm>
    #include<cstdio>
    #include<cmath>
    #include<cstring>
    #include<cstdlib>
    #include<cctype>
    #include<vector>
    #include<queue>
    #include<map>
    #include<set>
    using namespace std;
    typedef long long lld;
    typedef long double lf;
    typedef unsigned long long uld;
    typedef pair<int,int> pii;
    #define fi first
    #define se second
    #define pb push_back
    #define mk make_pair
    #define FOR(i,a,b) for(int i=(a);i<=(b);++i)
    #define ROF(i,a,b) for(int i=(a);i>=(b);--i)
    /******************heading******************/
    
    const int N=5e4+5;
    int n,T,m,k;
    int a[N];
    struct data{int l,r,id;}q[N];
    bool cmp(data x,data y){
        return x.l/T==y.l/T?x.r<y.r:x.l<y.l;
    }
    
    int l,r,cur;
    int c[N],ans[N];
    void addr(){cur+=2*c[a[++r]]+1, c[a[r]]++;}
    void decl(){cur+=2*c[a[--l]]+1,c[a[l]]++;}
    void decr(){cur+=-2*c[a[r]]+1, c[a[r--]]--;}
    void addl(){cur+=-2*c[a[l]]+1, c[a[l++]]--;}
    
    int main(){
        scanf("%d%d%d",&n,&m,&k);
        FOR(i,1,n)scanf("%d",&a[i]);
        FOR(i,1,m)scanf("%d%d",&q[i].l,&q[i].r), q[i].id=i;
        T=sqrt(n);
        sort(q+1,q+m+1,cmp);
        l=r=1,c[a[1]]++,cur=1;//init
        FOR(i,1,m){
            while(r<q[i].r)addr();
            while(l>q[i].l)decl();
            while(r>q[i].r)decr();
            while(l<q[i].l)addl();
            ans[q[i].id]=cur;
        }
        FOR(i,1,m)printf("%d
    ",ans[i]);
        return 0;
    }
    
    
  • 相关阅读:
    [C]static变量详解
    [LINUX]重定向
    [PHP]一些坑
    [PHP]常量的一些特性
    [数学]三角函数(一)
    [PHP]session的一些要点
    [C]控制外部变量访问权限的extern和static关键字
    c语言基础----共用体
    c语言基础----字符串数组
    c语言基础----函数库
  • 原文地址:https://www.cnblogs.com/sshwy/p/11102215.html
Copyright © 2011-2022 走看看