博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2019.01.26-bzoj2090: [Poi2010]Monotonicity 2
阅读量:6092 次
发布时间:2019-06-20

本文共 1279 字,大约阅读时间需要 4 分钟。

题目描述:

给出N个正整数a[1..N],再给出K个关系符号(>、<或=)s[1..k]。

选出一个长度为L的子序列(不要求连续),要求这个子序列的第i项和第i+1项的的大小关系为s[(i-1)mod K+1]。
求出L的最大值。

算法标签:dp,树状数组

思路:

令f[i]为第i位能最多匹配到的选出的子序列的第几位。然后可以由前向后转移,用树状数组维护,小于和大于的情况,等于的用一个数组维护即可。

讲的不清楚,其实看看代码也能很快理解。

以下代码:

#include
#define il inline#define _(d) while(d(isdigit(ch=getchar())))using namespace std;const int N=1e6+5;char s[5];int n,k,a[N],b[N],mx,t[2][N],p[N];il int read(){ int x,f=1;char ch; _(!)ch=='-'?f=-1:f;x=ch^48; _()x=(x<<1)+(x<<3)+(ch^48); return f*x;}il void ins(int op,int x,int v){ for(;x<=mx;x+=x&-x)t[op][x]=max(v,t[op][x]);}il int query(int op,int x){ int res=0; for(;x;x-=x&-x)res=max(res,t[op][x]); return res;}int main(){ n=read();k=read(); for(int i=1;i<=n;i++)a[i]=read(),mx=max(a[i],mx); for(int i=1;i<=k;i++){ scanf(" %s",s+1); if(s[1]=='<')b[i]=1; else if(s[1]=='=')b[i]=2; else b[i]=3; } int ans=0; for(int i=1;i<=n;i++){ int x=max(p[a[i]],max(query(0,a[i]-1),query(1,mx-a[i]))); int y=x%k+1;ans=max(ans,x+1); if(b[y]==1)ins(0,a[i],x+1); else if(b[y]==2)p[a[i]]=max(p[a[i]],x+1); else ins(1,mx-a[i]+1,x+1); } printf("%d\n",ans); return 0;}
View Code

 

转载于:https://www.cnblogs.com/Jessie-/p/10325585.html

你可能感兴趣的文章
【Python】《Python编程之美 最佳实践指南》读书笔记
查看>>
vim backspace设置选项详解
查看>>
我的友情链接
查看>>
c++中的构造函数和拷贝构造函数
查看>>
了解SYSDATE函数
查看>>
MySQL Query Analyzer查询分析器
查看>>
nagios全攻略(一)---准备阶段
查看>>
Windows 8 - 构建更健康的存储
查看>>
试验一下
查看>>
借助宁盾,搞定滴滴出行双因素认证解决方案
查看>>
Linux常用Debug命令
查看>>
Android4.4的zygote进程
查看>>
android 同步联系人
查看>>
27. 文件系统——编译安装源码格式的rpm包(src.rpm)
查看>>
IOS atomic与nonatomic,assign,copy与retain的定义和区别
查看>>
NO2
查看>>
rsync非典型运用
查看>>
LAMP架构搭建与优化(3.3-3.5)
查看>>
使用云祺虚拟机备份软件瞬时恢复Redhat RHV/Ovirt虚拟机
查看>>
中国首个 SaaS 模式的云告警平台安卓版 APP 上线
查看>>