[BZOJ3207] 花神的嘲讽计划Ⅰ (主席树)
Description
Input
Output
Sample Input
1 2 3 4 5 6 7 8
2 5 2 3 4
1 8 3 2 1
5 7 4 5 6
2 5 1 2 3
1 7 3 4 5
Sample Output
Yes
Yes
Yes
No
HINT
Source
Solution
CTSC上人生第一次写主席树,竟然过了,,,然后就兴(S)奋(B)地想找主席树的题巩固。有人说:不要在考试时写你不会的算法,或许是扯[哔——]吧。
先把所有长为k的串哈希,可以用线段树查询区间内某个数是否出现过。但这样就需要$n$棵树,而每棵树$3n$个结点。。。MLE*TLE等等。
窝们的HJT主席搞出来了一个数据结构,使得时空复杂度均为$O(nlogn)$(掌声在哪里)
嗯,就是搞两个指针,一个表示旧树,一个表示新树。树的结点表示某段权值区间内有多少个数。每棵树整体表示$[1, i]$区间内所有的数
因为相邻两棵树只有一个叶子结点不同,所以从根开始,一个儿子拷贝旧数的对应结点的标号,另一个儿子开一个新点,然后递归处理这个结点。因为每一次建树最多增加一条链的结点数$(logn)$,时间和空间复杂度就是$O(nlogn)$
查询答案时就是把$[1, r]$的答案减去$[1, l-1]$的答案,每次搜到叶子结点就结束,时间复杂度$O(mlogn)$
至此这道题就做完了。
(完了我自己都不知道自己在说些什么)
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
struct hjtree
{
int l, r, sum;
}a[];
int d[], ql[], qr[], ctot, root[], ptot;
ll sh[], cd[]; void update(int o1, int &o2, int l, int r, int id)
{
int mid = (l + r) >> ;
if(!o2) o2 = ++ptot;
a[o2].sum = a[o1].sum + ;
if(l == r) return;
if(id <= mid) a[o2].r = a[o1].r, update(a[o1].l, a[o2].l, l, mid, id);
else a[o2].l = a[o1].l, update(a[o1].r, a[o2].r, mid + , r, id);
} int query(int o1, int o2, int l, int r, int id)
{
int mid = (l + r) >> ;
if(l == r) return a[o2].sum - a[o1].sum;
if(id <= mid) return query(a[o1].l, a[o2].l, l, mid, id);
return query(a[o1].r, a[o2].r, mid + , r, id);
} int main()
{
int n, m, k, tmp;
scanf("%d%d%d", &n, &m, &k);
for(int i = ; i <= n; i++)
scanf("%d", d + i);
for(int i = ; i <= n - k + ; i++)
for(int j = ; j < k; j++)
sh[i] = sh[i] * + d[i + j];
for(int i = ; i <= n - k + ; i++)
cd[i] = sh[i];
for(int i = ; i <= m; i++)
{
scanf("%d%d", ql + i, qr + i);
for(int j = ; j <= k; j++)
{
scanf("%d", &tmp);
sh[n - k + + i] = sh[n - k + + i] * + tmp;
}
cd[n - k + + i] = sh[n - k + + i];
}
sort(cd + , cd + n - k + m + );
for(int i = ; i <= n - k + m + ; i++)
sh[i] = lower_bound(cd + , cd + n - k + m + , sh[i]) - cd;
for(int i = ; i <= n - k + ; i++)
update(root[i - ], root[i], , , (int)sh[i]);
for(int i = ; i <= m; i++)
puts(query(root[ql[i] - ], root[qr[i] - k + ], , , (int)sh[n - k + + i]) ? "No" : "Yes");
return ;
}
[BZOJ3207] 花神的嘲讽计划Ⅰ (主席树)的更多相关文章
- BZOJ3207花神的嘲讽计划Ⅰ——主席树+hash
题目描述 背景 花神是神,一大癖好就是嘲讽大J,举例如下: “哎你傻不傻的![hqz:大笨J]” “这道题又被J屎过了!!” “J这程序怎么跑这么快!J要逆袭了!” …… 描述 这一天DJ在给吾等众蒟 ...
- bzoj 3207 花神的嘲讽计划Ⅰ 主席树+hash
花神的嘲讽计划Ⅰ Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3112 Solved: 1086[Submit][Status][Discuss] ...
- BZOJ3207: 花神的嘲讽计划Ⅰ(hash)
3207: 花神的嘲讽计划Ⅰ Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3569 Solved: 1258[Submit][Status][Di ...
- [bzoj3207][花神的嘲讽计划Ⅰ] (字符串哈希+主席树)
Description 背景 花神是神,一大癖好就是嘲讽大J,举例如下: “哎你傻不傻的![hqz:大笨J]” “这道题又被J屎过了!!” “J这程序怎么跑这么快!J要逆袭了!” …… 描述 这一天D ...
- BZOJ3207 花神的嘲讽计划I
Time Limit: 10 Sec Memory Limit: 128 MB Summary 给你一个模式串P,q个询问,对每个询问回答从Pl到Pr是否存在与给定串相同的子串,同时有所有的给定串长度 ...
- BZOJ3207 花神的嘲讽计划
hash值建主席树. 垃圾题面没有熟虑范围害我MLE——>RE. By:大奕哥 #include<bits/stdc++.h> #define unll unsigned long ...
- [bzoj3207]花神的嘲讽计划Ⅰ[可持久化线段树,hash]
将每k个数字求一个哈希值,存入可持久化线段树,直接查询即可 #include <iostream> #include <algorithm> #include <cstd ...
- BZOJ3207: 花神的嘲讽计划Ⅰ
显然hash,然后stl随便搞. #include<bits/stdc++.h> #define N 100005 using namespace std; typedef unsigne ...
- 【字符串哈希】【莫队算法】bzoj3207 花神的嘲讽计划Ⅰ
既然询问的长度是确定的,那么我们可以将所有长度为K的字串弄个哈希值出来,这样字串存在性=>哈希值存在性. 自然上溢哈希,base=107比较不错. 序列长度n=>n-K+1 询问区间[x, ...
随机推荐
- [bzoj4551][Tjoi2016&Heoi2016]树-树链剖分
Brief Description 给定一颗有根树(根为1),有以下 两种操作:1. 标记操作:对某个结点打上标记(在最开始,只有结点1有标记,其他结点均无标记,而且对于某个 结点,可以打多次标记.) ...
- vim+makefile入门编辑,编译,差错实例
vim+makefile入门编辑,编译,差错实例 vim makefile 编译 编写代码,一般在vim中编辑完后,输入:wq,在命令行下输入g++ hello.cc -o hello ,出现问题,打 ...
- composer安装出现proc_open没有开启问题的解决方案
今天在安装下载项目的时候,使用composer来安装依赖.遇到了 The Process class relies on proc_open, which is not available on yo ...
- wpf 如何让控件左右移动
通过DoubleAnimation可以让控件进行左右移动. <Canvas x:Name="canvas_Shape" HorizontalAlignment="S ...
- Request processing failed; nested exception is java.lang.IllegalArgumentException: No converter found for return value of type: class cn.e3mall.pojo.TbItem
这个异常是缺少json相关的包 把以下依赖补上就好: <!-- Jackson Json处理工具包 --><dependency> <groupId>com.fas ...
- java调用shell脚本,并获得结果集的例子
/** * 运行shell脚本 * @param shell 需要运行的shell脚本 */ public static void execShell(String shell){ try { Run ...
- java:产生小数位数为2的随机概率,使得和为1
public static List<InstSec> setDataSec(List<String> instno) { List<InstSec> result ...
- for、for in和while以及do while
for循环:一般用在已知判断条件的循环; for(变量初始化;循环条件判断;循环后的执行){ 代码块 } //变量初始化可以省略,但是分号不能省.有多个的话用逗号隔开 //循环条件判断是true还是f ...
- loading加载动画
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 在Keil uv5里面添加STC元器件库,不影响其他元件
先到网上下载stc.CBD(http://download.csdn.net/detail/mao0514/9699117) 还有STC新系列单片机的头文件,宏晶的网站就有 1.在Keil/C51/I ...