数列找不同

这几乎就是莫队板子。

是否互不相同等价于判断 now==q[i].r-q[i].l+1 。

看代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e5+10;
int n,m,a[maxn],cnt[maxn],ans[maxn],now;
struct node{
    int l,r,id,bl;
}q[maxn];
int cmp(node x,node y){
    if(x.bl==y.bl)return x.r<y.r;
    return x.bl<y.bl;
}
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++)
        scanf("%d",&a[i]);
    int len=sqrt(n)+1;
    for(int i=1;i<=m;i++){
        scanf("%d%d",&q[i].l,&q[i].r);
        q[i].id=i;
        q[i].bl=q[i].l/len;
    }
    sort(q+1,q+1+m,cmp);
    int l=1,r=0;
    for(int i=1;i<=m;i++){
        while(l<q[i].l)now-=!(--cnt[a[l++]]);
        while(l>q[i].l)now+=!(cnt[a[--l]]++);
        while(r<q[i].r)now+=!(cnt[a[++r]]++);
        while(r>q[i].r)now-=!(--cnt[a[r--]]);
        ans[q[i].id]=(now==q[i].r-q[i].l+1);
    }
    for(int i=1;i<=m;i++)
        printf(ans[i]?"Yes\n":"No\n");
    return 0;
}

深深地感到自己的弱小。

原文链接: https://www.cnblogs.com/syzf2222/p/12465941.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;

也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬

    数列找不同

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/372524

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年3月3日 上午11:17
下一篇 2023年3月3日 上午11:19

相关推荐