题目链接:BZOJ - 3207

题目分析

先使用Hash,把每个长度为 k 的序列转为一个整数,然后题目就转化为了询问某个区间内有没有整数 x 。

这一步可以使用可持久化线段树来做,虽然感觉可以有更简单的做法,但是我没有什么想法...

代码

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <cstring>
#include <cmath> using namespace std; const int MaxN = 200000 + 5, P = 233, Mod = 3371723, MaxNode = 8000000 + 5; int n, m, k, en, TL_Index, Node_Index;
int A[MaxN], B[MaxN], Root[MaxN], Lc[MaxNode], Rc[MaxNode], T[MaxNode]; struct HashNode
{
int Pos, TL;
HashNode *Next;
} H[MaxN], *Ph = H, *Hash[Mod + 5]; bool Cmp(int *AA, int x, int *AB, int y) {
for (int i = 0; i < k; ++i)
if (AA[x + i] != AB[y + i]) return false;
return true;
} void Insert(int &Now, int Last, int s, int t, int x) {
if (Now == 0) Now = ++Node_Index;
if (s == t) {
T[Now] = T[Last] + 1;
return;
}
int m = (s + t) >> 1;
if (x <= m) {
Rc[Now] = Rc[Last];
Insert(Lc[Now], Lc[Last], s, m, x);
}
else {
Lc[Now] = Lc[Last];
Insert(Rc[Now], Rc[Last], m + 1, t, x);
}
} int main()
{
scanf("%d%d%d", &n, &m, &k);
for (int i = 1; i <= n; ++i) scanf("%d", &A[i]);
en = n - k + 1;
int HN, TL_i;
HashNode *Now;
TL_Index = 0;
Node_Index = 0;
for (int i = 1; i <= en; ++i) {
HN = 0;
for (int j = i; j < i + k; ++j) {
HN = HN * P + A[j];
if (HN > Mod) HN %= Mod;
}
Now = Hash[HN];
TL_i = 0;
while (Now != NULL) {
if (Cmp(A, i, A, Now -> Pos)) {
TL_i = Now -> TL;
break;
}
Now = Now -> Next;
}
if (TL_i == 0) {
++Ph; Ph -> Pos = i;
Ph -> TL = TL_i = ++TL_Index;
Ph -> Next = Hash[HN]; Hash[HN] = Ph;
}
Insert(Root[i], Root[i - 1], 1, n, TL_i);
}
int l, r, s, t, mid, x, y;
for (int i = 1; i <= m; ++i) {
scanf("%d%d", &l, &r);
for (int j = 1; j <= k; ++j) scanf("%d", &B[j]);
HN = 0;
for (int j = 1; j <= k; ++j) {
HN = HN * P + B[j];
if (HN > Mod) HN %= Mod;
}
TL_i = 0;
Now = Hash[HN];
while (Now != NULL) {
if (Cmp(B, 1, A, Now -> Pos)) {
TL_i = Now -> TL;
break;
}
Now = Now -> Next;
}
if (TL_i == 0 || r - l + 1 < k) printf("Yes\n");
else {
r = r - k + 1;
x = Root[l - 1]; y = Root[r];
s = 1; t = n;
while (s != t) {
mid = (s + t) >> 1;
if (TL_i <= mid) {
x = Lc[x]; y = Lc[y];
t = mid;
}
else {
x = Rc[x]; y = Rc[y];
s = mid + 1;
}
}
if (T[y] - T[x] > 0) printf("No\n");
else printf("Yes\n");
}
}
return 0;
}

  

[BZOJ 3207] 花神的嘲讽计划Ⅰ【Hash + 可持久化线段树】的更多相关文章

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

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

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

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

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

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

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

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

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

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

  6. BZOJ 3207 花神的嘲讽计划Ⅰ(函数式线段树)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=3207 题意:给出一个数列,若干询问.每个询问查询[L,R]区间内是否存在某个长度为K的子 ...

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

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

  8. BZOJ_3207_花神的嘲讽计划Ⅰ_哈希+主席树

    BZOJ_3207_花神的嘲讽计划Ⅰ_哈希+主席树 Description 背景 花神是神,一大癖好就是嘲讽大J,举例如下: “哎你傻不傻的![hqz:大笨J]” “这道题又被J屎过了!!” “J这程 ...

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

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

随机推荐

  1. cocoapods_第二篇

    一.什么是CocoaPods CocoaPods是iOS项目的依赖管理工具,该项目源码在Github上管理.开发iOS项目不可避免地要使用第三方开源库,CocoaPods的出现使得我们可以节省设置和第 ...

  2. PMD使用手册

    文中测试例子均采用JHotDraw7源码,官网关于 JHotDraw的检测结果:http://pmd.sourceforge.net/reports/jhotdraw_JHotDraw.html 下载 ...

  3. android 55

    智能家居:可以联网可以用指令操作可以返回状态.智能微波炉智能眼镜智能手表. Android作者Andy Rubin,2007年正式由谷歌推广,开源的. 安卓体系结构和开发一个闹钟的调用结构图: 安卓和 ...

  4. AlgorithmVisualizer

    http://jasonpark.me/AlgorithmVisualizer/#path=graph_search/floyd_warshall/shortest_paths

  5. JS根据key值获取URL中的参数值,以及把URL的参数转换成json对象

    //把url的参数部分转化成json对象 parseQueryString: function (url) { var reg_url = /^[^\?]+\?([\w\W]+)$/, reg_par ...

  6. C#生成缩略图不清晰模糊问题的解决方案!

    之前网上找了个生成缩略图的代码,改了改直接用了.问题来了,等比例缩略图时总是发现左边.上边的边线大概有一像素的白边,领导不乐意了,那咱就改吧.图片放大了才发现,那个好像是渐变的颜色,晕,这样的功能领导 ...

  7. 如何配置visual studio 2013进行负载测试-万事开头难

    声明:工作比较忙,文章写得不好,有时间再整理. 起因:最近众包平台因迁移到azure之后一直有网站慢的情况,让老板挨批了,但是测试环境一切正常,而且生产环境也没发现有卡顿和慢的情况,所以干脆来一次负载 ...

  8. 点击文字可以选中相应的checkbox

    <html><head><title>中国站长天空-网页特效-表单特效-点击文字选中的复选框</title><meta http-equiv=&q ...

  9. PHP上传原理及应用

    概要 1.FORM表现enctype属性 2.$_FILES系统函数 3.move_uploaded_file函数 4.is_uploaded_file函数 1.FORM标签的enctype属性 只有 ...

  10. 详细查看数据库SQL执行计划

    DBCC DROPCLEANBUFFERS 清除数据缓存DBCC FREEPROCCACHE  清除执行计划缓存 SET SHOWPLAN_XML ON 此语句导致 SQL Server 不执行 Tr ...