codevs 1283 等差子序列
http://codevs.cn/problem/1283/
给一个 1 到 N 的排列{Ai},询问是否存在 1<=p1<p2<p3<p4<p5<…<pLen<=N(Len>=3),使得 Ap1,Ap2,Ap3,…ApLen 是一个等差序列。
输入的第一行包含一个整数 T,表示组数。
下接 T 组数据,每组第一行一个整数 N,每组第二行为一个 1 到 N 的排列, 数字两两之间用空格隔开。
对于每组数据,如果存在一个等差子序列,则输出一行“Y”,否则输出一 行“N”。
2
3
1 3 2
3
3 2 1
N
Y
对于5%的数据,N<=100,对于30%的数据,N<=1000,对于100%的数据,N<=10000,T<=7
线段树+hash
首先要注意的是这个排列是1到n的排列
然后当然是找3个数形成等差子序列
暴力:枚举中间的数,枚举左边的数,枚举右边的数,看是否满足 2*mid=l+r
O(n³)
继续想,因为保证排列是1到n
所以对于一个数x,若以x为mid能形成等差子序列,那么另外两个数一定在x两侧
即从左往右枚举,当枚举到mid时,能早就枚举到了l,不能枚举到r
可以用0,1表示这个数是否被枚举到
举个例子:
3 6 1 2 4 5
当枚举到第5个数4时,0 1序列为
1 1 1 1 0 1
4的左边分别是1和0,说明枚举到4时,3已经被枚举到了,5还没有被枚举
但这样仍然要枚举,没有减少时间复杂度
如何去掉枚举的过程?
继续想,发现我们要比较的是mid左右的两个对称区间
举个例子:
1 8 3 6 5 7 4 2
当枚举到3时,0 1序列为:
1 0 1 0 0 0 0 1
我们实际需要的是判断2和4的01序列是否相等,1和5的01序列是否相等
因为是对称的
可以转化为判断区间[1,2]和区间[5,4](注意这里是[5,4],不是[4,5])是否相等
线段树维护区间正序哈希值和倒序哈希值,即可log判断
总复杂度:O(nlogn)
#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 10001
#define LL unsigned long long
using namespace std;
int T,n,x,len;
bool ok;
LL bit[N],hash[N*],anti_hash[N*],r1,r2;
struct TREE
{
public:
void up(int k,int l,int r)
{
hash[k]=hash[k<<]*bit[r-(l+r>>)]+hash[k<<|];
anti_hash[k]=anti_hash[k<<|]*bit[(l+r>>)-l+]+anti_hash[k<<];
}
void change(int k,int l,int r,int pos)
{
if(l==r)
{
anti_hash[k]=hash[k]=;
return;
}
int mid=l+r>>;
if(pos<=mid) change(k<<,l,mid,pos);
else change(k<<|,mid+,r,pos);
up(k,l,r);
}
LL query(int k,int l,int r,int opl,int opr,int w)
{
if(l>=opl&&r<=opr) return w== ? hash[k]:anti_hash[k];
int mid=l+r>>;
if(opr<=mid) return query(k<<,l,mid,opl,opr,w);
else if(opl>mid) return query(k<<|,mid+,r,opl,opr,w);
else if(w==) return query(k<<,l,mid,opl,mid,w)*bit[opr-mid]+query(k<<|,mid+,r,mid+,opr,w);
else return query(k<<|,mid+,r,mid+,opr,w)*bit[mid-opl+]+query(k<<,l,mid,opl,mid,w);
}
void solve(int i)
{
len=min(i-,n-i);
r1=query(,,n,i-len,i-,);
r2=query(,,n,i+,i+len,);
if(r1!=r2) ok=true;
}
}tree;
int main()
{
bit[]=; for(int i=;i<N;i++) bit[i]=bit[i-]*;
scanf("%d",&T);
while(T--)
{
memset(hash,,sizeof(hash));
memset(anti_hash,,sizeof(anti_hash));
scanf("%d",&n);
ok=false;
for(int i=;i<=n;i++)
{
scanf("%d",&x);
if(!ok)
{
tree.change(,,n,x);
if(x!=&&x!=n) tree.solve(x);
}
}
if(ok) puts("Y");
else puts("N");
}
}
codevs 1283 等差子序列的更多相关文章
- 1893. [国家集训队2011]等差子序列(bitset)
★★ 输入文件:nt2011_sequence.in 输出文件:nt2011_sequence.out 简单对比时间限制:0.3 s 内存限制:512 MB [试题来源] 2011中国 ...
- BZOJ 2124: 等差子序列
Sol 线段树+Hash. 首先暴力 等差子序列至少3项就可以了,就枚举中项,枚举公差就可以了,只需要一个数在中项前出现,另一个数在中项前没出现过就可以了.复杂度 \(O(n^2)\) 然后我想了一个 ...
- [bzoj2124]等差子序列(hash+树状数组)
我又来更博啦 2124: 等差子序列 Time Limit: 3 Sec Memory Limit: 259 MBSubmit: 941 Solved: 348[Submit][Statu ...
- 2124: 等差子序列 - BZOJ
Description 给一个1到N的排列{Ai},询问是否存在1<=p1=3),使得Ap1,Ap2,Ap3,…ApLen是一个等差序列. Input 输入的第一行包含一个整数T,表示组数.下接 ...
- BZOJ 2124等差子序列 线段树&&hash
[题目描述 Description] 给一个 1 到 N 的排列{Ai},询问是否存在 1<=p1<p2<p3<p4<p5<…<pLen<=N(Len& ...
- bzoj2124 等差子序列(hash+线段树)
2124: 等差子序列 Time Limit: 3 Sec Memory Limit: 259 MBSubmit: 719 Solved: 261[Submit][Status][Discuss] ...
- BZOJ_2124_等差子序列_线段树+Hash
BZOJ_2124_等差子序列_线段树+Hash Description 给一个1到N的排列{Ai},询问是否存在1<=p1<p2<p3<p4<p5<…<pL ...
- P2757 [国家集训队]等差子序列
P2757 [国家集训队]等差子序列 题目传送门 推荐一篇好题解 此题要求我们在一个序列中找出一个等差子序列. 显然,我们只需要考虑子序列长度len=3的情况,因为在长度为4的子序列中必定有一个长度为 ...
- CF452F Permutations/Luogu2757 等差子序列 树状数组、Hash
传送门--Luogu 传送门--Codeforces 如果存在长度\(>3\)的等差子序列,那么一定存在长度\(=3\)的等差子序列,所以我们只需要找长度为\(3\)的等差子序列.可以枚举等差子 ...
随机推荐
- [APIO2015]巴邻旁之桥
Bzoj权限题 luogu题面 先去掉同边的 首先k==1,即求一个点j 使\(\sum_{i\in A} |D_i - D_j| + \sum_{i\in B} |D_i - D_j|\)最小 因为 ...
- [BZOJ1070] [SCOI2007] 修车 (费用流 & 动态加边)
Description 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的.现在需要安排这M位技术人员所维修的车及顺序,使 ...
- 【最新】Power BI混合现实应用Mixed Reality app预览版正式发布
1.介绍 2018年3月13日,Power BI在官方博客和Docs文档发布了Power BI for Mixed Reality应用预览版的消息, 也就是可以以后在更虚拟的世界中来观察你的报表,想象 ...
- asp.net-基础-20180319
建立动态web . .net的一部分. HTML:超文本标记语言.WWW浏览器上文档的格式化语言. HTTP:超文本传输协议.WWW浏览器与服务器应用层通信协议. 静态页面:不需要服务器额外代码处理的 ...
- mysql, sql sever , oracle
一.sqlserver优点:易用性.适合分布式组织的可伸缩性.用于决策支持的数据仓库功能.与许多其他服务器软件紧密关联的集成性.良好的性价比等:为数据管理与分析带来了灵活性,允许单位在快速变化的环境中 ...
- 微信小程序调接口常见问题解决方法
第一次调接口时遇见的bug. 注意:接口的域名不能使用 IP 地址或 localhost,且不能带端口号: 微信小程序如何调接口? wx.request({ url: 'http://miniapp/ ...
- 使用axios向后端传递数据,后端接收不到?
开始使用axios的时候,按照官网的例子请求后端接口,遇到了后端接收不到数据的情况. 翻看了文档也没找到解决方法.先来了解下基本的axios 想要使用axios,需要先安装 npm install a ...
- 笔记:Spring Boot 配置详解
Spring Boot 针对常用的开发场景提供了一系列自动化配置来减少原本复杂而又几乎很少改动的模板配置内容,但是,我们还是需要了解如何在Spring Boot中修改这些自动化的配置,以应对一些特殊场 ...
- 笔记:Jersey REST API 设计
REST 统一接口 REST 使用 HTTP 协议的通用方法作为统一接口的标准词汇,REST 服务所提供的方法信息都在 HTTP 方法里,每一种HTTP请求方法都可以从安全性和幂等性两方面考虑,这对正 ...
- Redis学习笔记(三)常用命令整理
Redis 常用命令 1.DEL key 删除key2.EXISTS key 检查key是否存在3.KEYS * 查看所有的key4.EXPIRE key seconds 设置key的过期时间5.TT ...