• 静态莫队


    本质是带优化的双指针,对全部区间进行√n个块的分块操作,然后进行排序。第一关键字为查询的左端点块号,第二关键字为查询的右端点本身的位置。

    这里放一个洛谷例题

    P3901 数列找不同

    附上代码

    #pragma GCC optimize("O3")
    #include <bits/stdc++.h>
    #define N 100005
    using namespace std;
    inline int read()
    {
        register int x=0,f=1;char ch=getchar();
        while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
        while(ch>='0'&&ch<='9')x=(x<<3)+(x<<1)+ch-'0',ch=getchar();
        return x*f;
    }
    int v[N],blocksize=0;
    struct query{
        int l,r,id,bl;
    }q[N];
    int sum[N];
    bool ans[N];
    int cnt=0;
    inline void add(register int x)
    {
        if(++sum[v[x]]==1)
            ++cnt; 
    }
    inline void del(register int x)
    {
        if(--sum[v[x]]==0)
            --cnt;
    }
    inline bool cmp(register query a,register query b)
    {
        return a.bl!=b.bl?a.l<b.l:((a.bl&1)?a.r<b.r:a.r>b.r);
    }
    int main()
    {
        memset(sum,0,sizeof(sum));
        int n=read(),m=read();
        blocksize=sqrt(n);
        for(register int i=1;i<=n;++i)
            v[i]=read();
        for(register int i=1;i<=m;++i)
        {
            int l=read(),r=read();
            q[i]=(query){l,r,i,(l-1)/blocksize+1};
        }
        sort(q+1,q+m+1,cmp);
        int l=1,r=0;
        for(register int i=1;i<=m;++i)
        {
            int ll=q[i].l,rr=q[i].r;
            while(l<ll)
                del(l++);
            while(l>ll)
                add(--l);
            while(r<rr)
                add(++r);
            while(r>rr)
                del(r--);
            ans[q[i].id]=(cnt==rr-ll+1)?1:0;
        }
        for(register int i=1;i<=m;++i)
            if(ans[i])
                puts("Yes");
            else
                puts("No");
        return 0;
     } 
    rush!
  • 相关阅读:
    格式化数据和DataBinder.Eval用法范例【转】
    动态GridView +DataTable
    Container.DataItem
    SQL自定义字段排序
    VS 2008 Web Deployment Project
    清除SQLServer日志
    SQL常用功能
    在Web应用程序中执行计划任务(多线程)
    得到临时表的列数
    用rdlc文件直接导出到excel或PDF
  • 原文地址:https://www.cnblogs.com/LH2000/p/15044790.html
Copyright © 2020-2023  润新知