令$f_{i}$表示以$i$为结尾的最长上升子序列,显然可以快速预处理

令$L=\max_{i=1}^{n}f_{i}$,当$L$为偶数,考虑如下构造——

将所有$f_{i}\le \frac{L}{2}$的$a_{i}$选入第1个序列,其余位置选入第2个序列

此时,来证明两个序列的最长上升子序列都是$\frac{L}{2}$

考虑这个长为$L$的最长上升子序列,其前$\frac{L}{2}$个元素必然都在第1个序列中,后$\frac{L}{2}$个元素必然都在第2个序列中,即两者最长上升子序列长度都大于等于$\frac{L}{2}$

另一方面,第1个序列中以$i$为结尾的最长上升序列小于等于$\frac{L}{2}$,第2个序列中以$i$为起点的最长上升序列小于等于$\frac{L}{2}$(由于$f_{i}>\frac{L}{2}$,且两者之和小于等于$L$,即有此结论),也都小于等于$\frac{L}{2}$

(其中$i$为各自序列中任意元素)

当$L$为奇数,假设$L=2k+1$,那么对于其中一个长为$L$的上升子序列,要存在一个元素$x$,其不在此序列中,且存在一个长为$k+1$的上升子序列包含其

关于这件事情的必要性是显然的,同时其也是充分的,考虑如下构造——

任选一个长为$L$的上升子序列,根据此性质,选择$x$并假设这个$k+1$的上升子序列为$p_{1},p_{2},...,p_{k+1}$

将所有满足$\forall 1\le j\le k+1,f_{i}\ne f_{p_{j}}$或$f_{i}=f_{x}$且$i\ne x$的$a_{i}$选入第1个序列,其余位置选入第2个序列

在第1个序列中,考虑这个长为$L$的上升子序列,设其中第$i$个位置为$x$,即有$f_{x}=i$,恰好包含$[1,L]$中所有值,其中恰有$k$个值不能选($f_{i}=f_{x}$是可以选的),构成一个长为$k+1$的上升子序列

在第2个序列中,$p_{i}$都被选入第2个序列,也构成一个长为$k+1$个上升子序列

另一方面,对于一个长为$k$的上升子序列,每一个位置的$f_{x}$必然各不相同,而注意到两个序列中都至多含有$k+1$个不同的$f$,即不存在长为$k+2$的上升子序列

关于判定,求出以每一个元素为起点和终点的最长上升子序列,即可求出强制包含某个元素的最长上升子序列,判定其是否大于等于$k+1$即可

由此,即解决此问题,时间复杂度为$o(n\log n)$

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 200005
4 #define L (k<<1)
5 #define R (L+1)
6 #define mid (l+r>>1)
7 int t,n,ans,a[N],vis[N],f[N],g[N],mx[N<<2];
8 void build(int k,int l,int r){
9 mx[k]=0;
10 if (l==r)return;
11 build(L,l,mid);
12 build(R,mid+1,r);
13 }
14 void update(int k,int l,int r,int x,int y){
15 if (l==r){
16 mx[k]=y;
17 return;
18 }
19 if (x<=mid)update(L,l,mid,x,y);
20 else update(R,mid+1,r,x,y);
21 mx[k]=max(mx[L],mx[R]);
22 }
23 int query(int k,int l,int r,int x,int y){
24 if ((l>y)||(x>r))return 0;
25 if ((x<=l)&&(r<=y))return mx[k];
26 return max(query(L,l,mid,x,y),query(R,mid+1,r,x,y));
27 }
28 int main(){
29 scanf("%d",&t);
30 while (t--){
31 scanf("%d",&n);
32 for(int i=1;i<=n;i++)scanf("%d",&a[i]);
33 ans=0;
34 build(1,1,n);
35 for(int i=1;i<=n;i++){
36 f[i]=query(1,1,n,1,a[i]-1)+1;
37 update(1,1,n,a[i],f[i]);
38 ans=max(ans,f[i]);
39 }
40 if (ans%2==0)printf("YES\n");
41 else{
42 build(1,1,n);
43 for(int i=n;i;i--){
44 g[i]=query(1,1,n,a[i]+1,n)+1;
45 update(1,1,n,a[i],g[i]);
46 }
47 bool flag=0;
48 for(int i=n,j=ans;i;i--)
49 if (f[i]==j)j--;
50 else{
51 if (f[i]+g[i]-1>=ans/2+1){
52 printf("YES\n");
53 flag=1;
54 break;
55 }
56 }
57 if (!flag)printf("NO\n");
58 }
59 }
60 }

[atAGC052D]Equal LIS的更多相关文章

  1. Codeforces Round #371 (Div. 2)E. Sonya and Problem Wihtout a Legend[DP 离散化 LIS相关]

    E. Sonya and Problem Wihtout a Legend time limit per test 5 seconds memory limit per test 256 megaby ...

  2. 【HDU 4352】 XHXJ's LIS (数位DP+状态压缩+LIS)

    XHXJ's LIS Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  3. 1053. Path of Equal Weight (30)

    Given a non-empty tree with root R, and with weight Wi assigned to each tree node Ti. The weight of ...

  4. XHXJ's LIS(数位DP)

    XHXJ's LIS http://acm.hdu.edu.cn/showproblem.php?pid=4352 Time Limit: 2000/1000 MS (Java/Others)     ...

  5. HDU 4352 - XHXJ's LIS - [数位DP][LIS问题]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4352 Time Limit: 2000/1000 MS (Java/Others) Memory Li ...

  6. hdu 4352 XHXJ's LIS 数位dp+状态压缩

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4352 XHXJ's LIS Time Limit: 2000/1000 MS (Java/Others ...

  7. POJ 1836-Alignment(DP/LIS变形)

    Alignment Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 13465   Accepted: 4336 Descri ...

  8. poj 1836 LIS变形

    题目链接http://poj.org/problem?id=1836 Alignment Time Limit: 1000MS   Memory Limit: 30000K Total Submiss ...

  9. CodeForces - 650D:Zip-line (LIS & DP)

    Vasya has decided to build a zip-line on trees of a nearby forest. He wants the line to be as long a ...

随机推荐

  1. DL4J实战之二:鸢尾花分类

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  2. docker采用registry部署简易仓库

    解释:registry部署简易仓库,实现免密上传拉取镜像(解决不在一个容器里,也能够实现镜像拉取成功) 1.安装启动registry服务 docker pull registry docker run ...

  3. Serverless 工程实践 | 零基础上手 Knative 应用

    作者|刘宇 前言:Knative 是一款基于 Kubernetes 的 Serverless 框架.其目标是制定云原生.跨平台的 Serverless 编排标准. Knative 介绍 Knative ...

  4. ElasticSearch IK热词自动热更新原理与Golang实现

    热更新概述 ik分词器本身可以从配置文件加载扩张词库,也可以从远程HTTP服务器加载. 从本地加载,则需要重启ES生效,影响比较大.所以,一般我们都会把词库放在远程服务器上.这里主要有2种方式: 借助 ...

  5. 洛谷1501 Tree II(LCT,路径修改,路经询问)

    这个题是一个经典的维护路径信息的题,对于路径上的修改,我们只需要把对应的链\(split\)上来,然后修改最上面的点就好,注意pushdown的时候的顺序是先乘后加 然后下传乘法标记的时候,记得把对应 ...

  6. 使用CSS选择器(第二部分)

    伪类跟伪元素一样,并不是直接针对文档元素的,而是为你基于某些共同特征选择元素提供方便. 使用结构性伪类选择器 使用结构性伪类选择器能够根据元素在文档中的位置选择元素.这类选择器都有一个冒号字符前缀(: ...

  7. Go语言核心36讲(Go语言基础知识六)--学习笔记

    06 | 程序实体的那些事儿 (下) 在上一篇文章,我们一直都在围绕着可重名变量,也就是不同代码块中的重名变量,进行了讨论.还记得吗? 最后我强调,如果可重名变量的类型不同,那么就需要引起我们的特别关 ...

  8. Flask聚合函数(基本聚合函数、分组聚合函数、去重聚合函数))

    Flask聚合函数 1.基本聚合函数(sun/count/max/min/avg) 使用聚合函数先导入:from sqlalchemy import func 使用方法: sun():func.sum ...

  9. 【UE4 C++】读写Text文件 FFileHelper

    CoreMisc.h 读取 FFileHelper::LoadFileToString 读取全部内容,存到 FString FString TextPath = FPaths::ProjectDir( ...

  10. 轻松掌握stm32直流电机驱动与测速

    说实话就现在的市场应用中stm32已经占到了绝对住到的地位,51已经成为过去式,32的功能更加强大,虽然相应的难度有所增加,但是依然阻止不了大家学习32的脚步,不说大话了这些大家都懂要不然也不会学习s ...