题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=3207

题意:给出一个数列,若干询问。每个询问查询[L,R]区间内是否存在某个长度为K的子数列(连续的)。

思路:将长度为K的每个子数列哈希成一个值,将查询也哈希成一个值,建立函数式线段树,然后对于查询[L,R],查询个数是否大于0。

int n,m,K,a[N];
int st[N],ed[N];
u64 b[N],bNum;
u64 p[N],q[N];

u64 getHash(int L,int R)
{
    u64 ans=0;
    int i;
    for(i=L;i<=R;i++) ans=ans*107+a[i];
    return ans;
}

struct node
{
    int L,R,a,b,s;
};

node tree[N<<4];
int root[N],tot;

int build(int a,int b)
{
    int k=++tot;
    tree[k].a=a;
    tree[k].b=b;
    tree[k].s=0;
    int mid=(a+b)>>1;
    if(a!=b)
    {
        tree[k].L=build(a,mid);
        tree[k].R=build(mid+1,b);
    }
    return k;
}

int insert(int p,int x)
{
    int k=++tot;
    tree[k]=tree[p];
    tree[k].s++;
    if(tree[k].a==x&&tree[k].b==x) return k;
    int mid=(tree[k].a+tree[k].b)>>1;
    if(x<=mid) tree[k].L=insert(tree[p].L,x);
    else tree[k].R=insert(tree[p].R,x);
    return k;
}

int get(int p,int x)
{
    if(tree[p].a==tree[p].b) return tree[p].s;
    int mid=(tree[p].a+tree[p].b)>>1;
    if(x<=mid) return get(tree[p].L,x);
    else get(tree[p].R,x);
}

int main()
{
    RD(n,m,K);
    int i;
    FOR1(i,n) RD(a[i]);
    bNum=n-K+1;
    FOR1(i,bNum) p[i]=b[i]=getHash(i,i+K-1);
    int j,x;
    u64 t;
    FOR1(i,m)
    {
        RD(st[i],ed[i]); ed[i]=ed[i]-K+1;
        t=0;
        FOR1(j,K) RD(x),t=t*107+x;
        q[i]=b[++bNum]=t;
    }
    sort(b+1,b+bNum+1);
    root[0]=build(1,bNum);
    FOR1(i,n-K+1)
    {
        a[i]=lower_bound(b+1,b+bNum+1,p[i])-b;
        root[i]=insert(root[i-1],a[i]);
    }
    FOR1(i,m)
    {
        x=lower_bound(b+1,b+bNum+1,q[i])-b;
        if(get(root[ed[i]],x)-get(root[st[i]-1],x)>0) puts("No");
        else puts("Yes");
    }
}

BZOJ 3207 花神的嘲讽计划Ⅰ(函数式线段树)的更多相关文章

  1. BZOJ 3207: 花神的嘲讽计划Ⅰ( hash + 可持久化线段树 )

    O(NK)暴力搞出所有子串的哈希值, 然后就对哈希值离散化建权值线段树, 就是主席树的经典做法了.总时间复杂度O(NK+(N+Q)logN) ----------------------------- ...

  2. bzoj 3207 花神的嘲讽计划Ⅰ 主席树+hash

    花神的嘲讽计划Ⅰ Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 3112  Solved: 1086[Submit][Status][Discuss] ...

  3. [BZOJ 3207] 花神的嘲讽计划Ⅰ【Hash + 可持久化线段树】

    题目链接:BZOJ - 3207 题目分析 先使用Hash,把每个长度为 k 的序列转为一个整数,然后题目就转化为了询问某个区间内有没有整数 x . 这一步可以使用可持久化线段树来做,虽然感觉可以有更 ...

  4. bzoj 3207: 花神的嘲讽计划Ⅰ

    Description 背景 花神是神,一大癖好就是嘲讽大J,举例如下: "哎你傻不傻的![hqz:大笨J]" "这道题又被J屎过了!!" "J这程序 ...

  5. bzoj 3207 花神的嘲讽计划Ⅰ(哈希法+主席树)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3207 [题意] 给定一个文本串,多次询问K长的模式串是否在文本[l,r]区间内出现. ...

  6. BZOJ 3207: 花神的嘲讽计划Ⅰ(莫队+哈希)

    传送门 解题思路 刚开始写了个莫队+哈希+\(map\)的\(O(n\sqrt(n)log(n)\)的辣鸡做法,\(T\)飞了.后来看了看别人博客发现其实并不用拿\(map\)当桶存那些哈希值.因为只 ...

  7. 【BZOJ3207】花神的嘲讽计划Ⅰ Hash+主席树

    [BZOJ3207]花神的嘲讽计划Ⅰ Description 背景 花神是神,一大癖好就是嘲讽大J,举例如下: “哎你傻不傻的![hqz:大笨J]” “这道题又被J屎过了!!” “J这程序怎么跑这么快 ...

  8. 【BZOJ】【3207】花神的嘲讽计划 I

    字符串Hash+可持久化线段树 好神奇的转化…… 蒟蒻一开始还去想AC自动机去了……然而由于a[i]的范围是小于等于n,怎么也想不出一个时间复杂度合理的方法 膜拜了题解0.0原来是字符串Hash! 首 ...

  9. 【BZOJ3207】花神的嘲讽计划I 可持久化线段树/莫队

    看到题目就可以想到hash 然后很自然的联想到可持久化权值线段树 WA:base取了偶数 这道题还可以用莫队做,比线段树快一些 可持久化线段树: #include<bits/stdc++.h&g ...

随机推荐

  1. 2016 系统设计第一期 (档案一)MVC 控制器接收表单数据

    1.FormCollection collection   user.UserId =Convert.ToInt32(collection["UserId"]); /// < ...

  2. verilogHDL设计中的同步时序逻辑

    引用自夏宇闻教授 1.同步时序逻辑: 是指表示状态的寄存器组的值只能在唯一确定的触发条件发生改变. 只能由时钟的正跳变沿或者负跳变沿触发的状态机就是一例,always@(posedge clk). 1 ...

  3. 【转载】Spring加载resource时classpath*:与classpath:的区别

    免责声明:     本文转自网络文章,转载此文章仅为个人收藏,分享知识,如有侵权,请联系博主进行删除.     原文作者:kyfxbl     原文地址: spring配置中classpath和cla ...

  4. BZOJ1692: [Usaco2007 Dec]队列变换

    1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 594  Solved: 246[Submit][Sta ...

  5. Unit Test Generator

           

  6. memmove和memcpy 以及strcmp strcpy几个库函数的实现

    memmove和memcpy 1.memmove 函数原型:void *memmove(void *dest, const void *source, size_t count) 返回值说明:返回指向 ...

  7. c#中HttpWebRequest使用Proxy实现指定IP的域名请求

    原文:http://www.cnblogs.com/greenerycn/archive/2010/04/11/httpwebreques_host_modify_By_set_proxy.html ...

  8. Floodlight 防火墙是如何起作用的

    前言 用mininet + floodlight搭建好环境之后,运行flooglight,然后在mininet中建立网络拓扑,建好之后,pingall,所有host之间可以ping通. 然后向控制器f ...

  9. 关于fisher判别的一点理解

    最近一个朋友问这方面的一些问题,其实之前也就很粗略的看了下fisher,真正帮别人解答问题的时候才知道原来自己也有很多东西不懂.下面小结下自己对fisher判别的理解: 其实fisher和PCA差不多 ...

  10. [codility]CountDiv

    https://codility.com/demo/take-sample-test/count_div 此题比较简单,是在O(1)时间里求区间[A,B]里面能被K整除的数字,那么就计算一下就能得到. ...