BZOJ 2124: 等差子序列
Sol
线段树+Hash.
首先暴力 等差子序列至少3项就可以了,就枚举中项,枚举公差就可以了,只需要一个数在中项前出现,另一个数在中项前没出现过就可以了.复杂度 \(O(n^2)\)
然后我想了一个虽然复杂度没变(因为我不会设计这个数据结构...) 但是好像有点用的算法,就是枚举中项,考虑从一个中项转移到另一个中项,那就是 \(\pm \Delta\) 就可以了...如果能够用数据结构维护这个操作,那就灰常好了.变换中项也就是变换折叠的位置吧.
标算呢...就是用线段树维护Hash,一个数字出现过,那就为1,没出现过就为0,维护一个正反序的01序列,如果一个数的 小于它正序01序列 和 大于它的反序01序列 异或值不为0那么就存在满足条件的等差序列.
01串太长了就可以用Hash来维护了...
PS:100000007不是质数...没开Long Long 直接见祖宗.
PS:我常数好大啊QAQ
Code
/**************************************************************
Problem: 2124
User: BeiYu
Language: C++
Result: Accepted
Time:2348 ms
Memory:8720 kb
****************************************************************/ #include<cstdio>
#include<cstring>
#include<iostream>
using namespace std; typedef long long LL;
const int N = 100005;
const LL p = 100000007;
#define debug(a) cout<<#a<<"="<<a<<" "
#define mid ((l+r)>>1)
#define lc (o<<1)
#define rc (o<<1|1) int T,n;
int a[N];
LL h1[N<<2],h2[N<<2],pow[N]; inline int in(int x=0,char ch=getchar()){ while(ch>'9'||ch<'0') ch=getchar();
while(ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();return x; } inline void Update(int x,int o,int l,int r){
if(l==r){ h1[o]=h2[o]=1;return; }
if(x<=mid) Update(x,lc,l,mid);
else Update(x,rc,mid+1,r);
h1[o]=(h1[lc]+h1[rc]*pow[mid-l+1])%p;
h2[o]=(h2[lc]*pow[r-mid]+h2[rc])%p;
}
inline LL Query1(int L,int R,int o,int l,int r){
if(L>R) return -1;
// debug(L),debug(R),debug(l),debug(r)<<endl;
if(L==l&&r==R) return h1[o];
if(L<=mid&&R>mid) return (Query1(L,mid,lc,l,mid)+Query1(mid+1,R,rc,mid+1,r)*pow[mid-L+1])%p;
if(L<=mid) return Query1(L,R,lc,l,mid)%p;
else return Query1(L,R,rc,mid+1,r)%p;
// debug(res)<<endl;
// return res;
}
inline LL Query2(int L,int R,int o,int l,int r){
if(L>R) return -1;
if(L==l&&r==R) return h2[o];
if(L<=mid&&R>mid) return (Query2(L,mid,lc,l,mid)*pow[R-mid]+Query2(mid+1,R,rc,mid+1,r))%p;
if(L<=mid) return Query2(L,R,lc,l,mid)%p;
else return Query2(L,R,rc,mid+1,r)%p;
// return res;
}
int main(){
pow[0]=1;for(int i=1;i<N;i++) pow[i]=(pow[i-1]<<1)%p;
for(T=in();T--;){
n=in();for(int i=1;i<=n;i++) a[i]=in();
int f=0;
memset(h1,0,sizeof(h1)),memset(h2,0,sizeof(h2));
for(int i=1;i<=n;i++){
int l=min(n-a[i],a[i]-1);
int u=Query2(a[i]-l,a[i]-1,1,1,n);
int v=Query1(a[i]+1,a[i]+l,1,1,n);
// cout<<"*********"<<endl;
// debug(i)<<endl;
// debug(l),debug(a[i])<<endl;
// debug(a[i]-l),debug(a[i]-1)<<endl;
// debug(a[i]+1),debug(a[i]+l)<<endl;
// cout<<u<<" "<<v<<endl;
if(u!=v){ f=1;break; }
Update(a[i],1,1,n);
}if(f) puts("Y");else puts("N");
}
return 0;
}
BZOJ 2124: 等差子序列的更多相关文章
- bzoj 2124 等差子序列 (线段树维护hash)
2124: 等差子序列 Time Limit: 3 Sec Memory Limit: 259 MBSubmit: 1922 Solved: 714[Submit][Status][Discuss ...
- BZOJ 2124: 等差子序列 线段树维护hash
2124: 等差子序列 Description 给一个1到N的排列{Ai},询问是否存在1<=p1=3),使得Ap1,Ap2,Ap3,…ApLen是一个等差序列. Input 输入的第一行包含一 ...
- BZOJ 2124等差子序列 线段树&&hash
[题目描述 Description] 给一个 1 到 N 的排列{Ai},询问是否存在 1<=p1<p2<p3<p4<p5<…<pLen<=N(Len& ...
- bzoj 2124 等差子序列 树状数组维护hash+回文串
等差子序列 Time Limit: 3 Sec Memory Limit: 259 MBSubmit: 1919 Solved: 713[Submit][Status][Discuss] Desc ...
- 2124: 等差子序列 - BZOJ
Description 给一个1到N的排列{Ai},询问是否存在1<=p1=3),使得Ap1,Ap2,Ap3,…ApLen是一个等差序列. Input 输入的第一行包含一个整数T,表示组数.下接 ...
- BZOJ [P2124] 等差子序列
线段树维护哈希值 要求出现长度大于三的等差子序列,我们只要找到长度等于三的就可以了 初看本题没有思路,只能暴力枚举,O(n^4) 后来发现,这个序列是n的一个排列,那么每个数字都只会出现一次 我们可以 ...
- [bzoj2124]等差子序列(hash+树状数组)
我又来更博啦 2124: 等差子序列 Time Limit: 3 Sec Memory Limit: 259 MBSubmit: 941 Solved: 348[Submit][Statu ...
- bzoj2124 等差子序列(hash+线段树)
2124: 等差子序列 Time Limit: 3 Sec Memory Limit: 259 MBSubmit: 719 Solved: 261[Submit][Status][Discuss] ...
- BZOJ2124: 等差子序列(树状数组&hash -> bitset 求是否存在长度为3的等差数列)
2124: 等差子序列 Time Limit: 3 Sec Memory Limit: 259 MBSubmit: 2354 Solved: 826[Submit][Status][Discuss ...
随机推荐
- CodeForces 689B Mike and Shortcuts (BFS or 最短路)
题目链接:http://codeforces.com/problemset/problem/689/B 题目大意: 留坑 明天中秋~
- ecshop自动退出
在使用ecshop后台的时候,老是自动退出,影响正常使用. 解决办法: 在includes/cls_session.php中,function gen_session_key($session_id) ...
- 取出return array() 数组内容
d.php文件 return array( "0" => 内容一, "1" => 内容二, "2" => 内容三, &qu ...
- Lua弱引用table
弱引用table 与python等脚本语言类似地,Lua也采用了自动内存管理(Garbage Collection),一个程序只需创建对象,而无需删除对象.通过使用垃圾收集机制,Lua会自动删除过期对 ...
- 浅谈JavaScript中的事件
引言 Html页面与JavaScript之间的交互是通过事件来完成的.事件,就是文档或者浏览器窗口中发生的一些特定的交互瞬间.可以使用侦听器(处理程序)来预订事件,以便事件发生时执行相应的代码.这在传 ...
- SQLSERVER2008R2正确使用索引
T1表 10000000万条数据,(插入时间36分钟,count(*)查询19秒,空间占用670M左右) 1.真正充分的利用索引比如like '张%' 就是符合SARG(符合扫描参数)标准而like ...
- HITtrainning20140417题解
题目列表: ID Origin Title 10 / 15 Problem A FZU 2152 文件系统 0 / 16 Problem B FZU 2153 A simple geome ...
- 利用afxDump来调试自己的程序
http://blog.csdn.net/sstower/article/details/7714199
- etcd
https://github.com/silenceper/dcmp http://studygolang.com/topics/1866
- nyoj 14 会场安排问题(贪心专题)
会场安排问题 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办.小刘的工 ...