[补档][Poi2010]Monotonicity 2
[Poi2010]Monotonicity 2
题目
给出N个正整数a[1..N],再给出K个关系符号(>、<或=)s[1..k]。选出一个长度为L的子序列(不要求连续),要求这个子序列的第i项和第i+1项的的大小关系为s[(i-1)mod K+1]。求出L的最大值。INPUT
第一行两个正整数,分别表示N和K (N, K <= 500,000)。第二行给出N个正整数,第i个正整数表示a[i] (a[i] <= 10^6)。第三行给出K个空格隔开关系符号(>、<或=),第i个表示s[i]。OUTPUT
一个正整数,表示L的最大值。SAMPLE
INPUT
7 32 4 3 1 3 5 3< > =OUTPUT
6
解题报告
for(int i=;i<=n;i++){
f[i]=;
for(int j=;j<=i-;j++){
int tmp(f[j]%k+);
if(op[tmp]=='='&&a[j]==a[i]&&f[j]+>f[i])
f[i]=f[j]+;
if(op[tmp]=='>'&&a[j]>a[i]&&f[j]+>f[i])
f[i]=f[j]+;
if(op[tmp]=='<'&&a[j]<a[i]&&f[j]+>f[i])
f[i]=f[j]+;
}
}
权值线段树
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
inline int read(){
int sum();
char ch(getchar());
for(;ch<''||ch>'';ch=getchar());
for(;ch>=''&&ch<='';sum=sum*+(ch^),ch=getchar());
return sum;
}
inline char init(){
char ch(getchar());
for(;ch!='='&&ch!='>'&&ch!='<';ch=getchar());
return ch;
}
inline int my_max(int a,int b){
return a>b?a:b;
}
int n,k;
int a[],op[];
int tr_d[],tr_x[],tr_e[];
int ad_d[],ad_x[],ad_e[];
inline void pushup_d(int i){
tr_d[i]=my_max(tr_d[i<<],tr_d[i<<|]);
}
inline void pushup_x(int i){
tr_x[i]=my_max(tr_x[i<<],tr_x[i<<|]);
}
inline void pushup_e(int i){
tr_e[i]=my_max(tr_e[i<<],tr_e[i<<|]);
}
inline void pushdown_d(int i){
if(ad_d[i]){
ad_d[i<<]=ad_d[i];
ad_d[i<<|]=ad_d[i];
tr_d[i<<]=ad_d[i];
tr_d[i<<|]=ad_d[i];
tr_d[i]=ad_d[i];
ad_d[i]=;
}
}
inline void pushdown_x(int i){
if(ad_x[i]){
ad_x[i<<]=ad_x[i];
ad_x[i<<|]=ad_x[i];
tr_x[i<<]=ad_x[i];
tr_x[i<<|]=ad_x[i];
tr_x[i]=ad_x[i];
ad_x[i]=;
}
}
inline void pushdown_e(int i){
if(ad_e[i]){
ad_e[i<<]=ad_e[i];
ad_e[i<<|]=ad_e[i];
tr_e[i<<]=ad_e[i];
tr_e[i<<|]=ad_e[i];
tr_e[i]=ad_e[i];
ad_e[i]=;
}
}
inline void update_d(int ll,int rr,int c,int l,int r,int i){
if(ll<=l&&r<=rr){
ad_d[i]=c;
tr_d[i]=c;
return;
}
pushdown_d(i);
int mid((l+r)>>);
if(ll<=mid)
update_d(ll,rr,c,l,mid,i<<);
if(rr>mid)
update_d(ll,rr,c,mid+,r,i<<|);
pushup_d(i);
}
inline void update_x(int ll,int rr,int c,int l,int r,int i){
if(ll<=l&&r<=rr){
ad_x[i]=c;
tr_x[i]=c;
return;
}
pushdown_x(i);
int mid((l+r)>>);
if(ll<=mid)
update_x(ll,rr,c,l,mid,i<<);
if(rr>mid)
update_x(ll,rr,c,mid+,r,i<<|);
pushup_x(i);
}
inline void update_e(int ll,int rr,int c,int l,int r,int i){
if(ll<=l&&r<=rr){
ad_e[i]=c;
tr_e[i]=c;
return;
}
pushdown_e(i);
int mid((l+r)>>);
if(ll<=mid)
update_e(ll,rr,c,l,mid,i<<);
if(rr>mid)
update_e(ll,rr,c,mid+,r,i<<|);
pushup_e(i);
}
inline int query_d(int ll,int rr,int l,int r,int i){
if(ll>rr)
return ;
if(ll<=l&&r<=rr)
return tr_d[i];
pushdown_d(i);
int mid((l+r)>>);
int ret();
if(ll<=mid)
ret=my_max(ret,query_d(ll,rr,l,mid,i<<));
if(rr>mid)
ret=my_max(ret,query_d(ll,rr,mid+,r,i<<|));
return ret;
}
inline int query_x(int ll,int rr,int l,int r,int i){
if(ll>rr)
return ;
if(ll<=l&&r<=rr)
return tr_x[i];
pushdown_x(i);
int mid((l+r)>>);
int ret();
if(ll<=mid)
ret=my_max(ret,query_x(ll,rr,l,mid,i<<));
if(rr>mid)
ret=my_max(ret,query_x(ll,rr,mid+,r,i<<|));
return ret;
}
inline int query_e(int ll,int rr,int l,int r,int i){
if(ll>rr)
return ;
if(ll<=l&&r<=rr)
return tr_e[i];
pushdown_e(i);
int mid((l+r)>>);
int ret();
if(ll<=mid)
ret=my_max(ret,query_e(ll,rr,l,mid,i<<));
if(rr>mid)
ret=my_max(ret,query_e(ll,rr,mid+,r,i<<|));
return ret;
}
int f[];
int mx();
int main(){
n=read(),k=read();
for(int i=;i<=n;i++)
a[i]=read(),mx=my_max(mx,a[i]);
for(int i=;i<=k;i++){
char ch(init());
if(ch=='>')
op[i]=;
if(ch=='<')
op[i]=;
if(ch=='=')
op[i]=;
}
f[]=;
if(op[]==)
update_d(a[],a[],f[],,mx,);
if(op[]==)
update_x(a[],a[],f[],,mx,);
if(op[]==)
update_e(a[],a[],f[],,mx,);
for(int i=;i<=n;i++){
int now(a[i]);
int ans_d(query_d(now+,mx,,mx,));
int ans_x(query_x(,now-,,mx,));
int ans_e(query_e(now,now,,mx,));
int ans(my_max(my_max(ans_d,ans_x),ans_e));
f[i]=ans+;
int o(op[ans%k+]);//cout<<i<<' '<<f[i]<<' '<<o<<endl;
if(o==)
update_d(now,now,f[i],,mx,);
if(o==)
update_x(now,now,f[i],,mx,);
if(o==)
update_e(now,now,f[i],,mx,);
}
int mxx();
for(int i=;i<=n;i++)
mxx=my_max(mxx,f[i]);
printf("%d",mxx);
}
[补档][Poi2010]Monotonicity 2的更多相关文章
- [补档]暑假集训D3总结
考试 集训第一次考试,然而- - 总共四道题,两道打了DFS,一道暴力,一道~~输出样例~~乱搞,都是泪啊- - 目前只改了三道,回头改完那道题再上题解吧- - T2 [Poi2010]Monot ...
- BZOJ2090: [Poi2010]Monotonicity 2【线段树优化DP】
BZOJ2090: [Poi2010]Monotonicity 2[线段树优化DP] Description 给出N个正整数a[1..N],再给出K个关系符号(>.<或=)s[1..k]. ...
- 【BZOJ2090/2089】[Poi2010]Monotonicity 2 动态规划+线段树
[BZOJ2090/2089][Poi2010]Monotonicity Description 给出N个正整数a[1..N],再给出K个关系符号(>.<或=)s[1..k].选出一个长度 ...
- STL 补档
STL 补档 1.vector 作用:它能够像容器一样存放各种类型的对象,简单地说,vector是一个能够存放任意类型的动态数组,能够增加和压缩数据. vector在C++标准模板库中的部分内容,它是 ...
- 图论补档——KM算法+稳定婚姻问题
突然发现考前复习图论的时候直接把 KM 和 稳定婚姻 给跳了--emmm 结果现在刷训练指南就疯狂补档.QAQ. KM算法--二分图最大带权匹配 提出问题 (不严谨定义,理解即可) 二分图 定义:将点 ...
- [补档] 大假期集训Part.1
新博客搭起来先补一发档... 那就从大假期集训第一部分说起好了QwQ 自己还是太菜掉回了2016级水平 day1: day1的时候来得有点晚(毕竟准高一)然后进机房发现早就开考了还没有给我题面于是搞了 ...
- 软件安装配置笔记(三)——ArcGIS系列产品安装与配置(补档)(附数据库连接及数据导入)
在前两篇安装配置笔记之后,就忘记把其他安装配置笔记迁移过来了,真是失误失误!趁现在其他文档需要赶紧补上. 目录: 一.ArcMap 二.ArcMap连接数据库并导入数据 三.Arcgis Pro 四. ...
- 补档 Codeblocks下的文件标题栏(标签)显示方法
可能在以下链接也能看到这篇文档 我知道很多人都不知道这个到底叫啥,还不如直接一点: 文件标题栏 就是如下的效果. 解决办法: 在左上角第三个view下,打开后取消Hide editor tabs 选项 ...
- [BZOJ2090/2089] [Poi2010]Monotonicity 2/Monotonicity 树状数组优化dp
这个dp乍看不科学,仔细一看更不科学,所以作为一个执着BOY,我决定要造数据卡死波兰人民,但是我造着造着就......证出来了......... 这个就是把 < > =分开讨论每次找到f[ ...
随机推荐
- javascript中apply,call,bind区别,bind兼容等问题总结
1 三者的相似之处: (1).都是用来改变函数的this对象的指向的 (2).都是用第一个参数来做this对象的指向 (3).都可以传参数进去 那么,具体到它们有什么区别呢?请看下面的例子: 两个对象 ...
- (6)javascript的程序控制结构及语句-----(1)条件判断
程序控制结构及语句 编程就是将现实应用,转换为程序能够读得懂的语法语句.Javascript编程中对程序流程控制主要是通过条件判断语句.循环控制语句及continue.break来完成的,其中条件判断 ...
- Swift字符串插值
字符串插值是一种全新的构建字符串的方式,可以在其中包含常量.变量.字面量和表达式.您插入的字符串字面量的每一项都被包裹在以反斜线为前缀的圆括号中: let multiplier = let messa ...
- 搭建es6开发与非开发环境babel-browser
前言 最近打算把es6应用到项目中,但是如何在开发环境(浏览器端)直接运行es6?es6已经发布一段时间了,现在大部分是在node.js环境运行,或者通过babel编译之后运行.babel-brows ...
- [leetcode-565-Array Nesting]
A zero-indexed array A consisting of N different integers is given. The array contains all integers ...
- create groups 和 create folder reference
当将文件拖入工程中的时候会出现这个对话框,这个对话框中在Added folders中有两种选择:Create groups 和 Create folder references 这两种的区别是 ...
- 程序员必须知道的六大ES6新特性
二 .字符串扩展 1.传统上,JavaScript只有indexOf方法,可以用来确定一个字符串是否包含在另一个字符串中.ES6又提供了三种新方法. includes():返回布尔值,表示是否找到了参 ...
- KBEngine简单RPG-Demo源码解析(2)
七:服务端资产库文件夹结构http://kbengine.org/cn/docs/concepts/directorys.html看assets, 注意:demo使用的不是默认的assets资产目录, ...
- Ajax 向后台提交一个 JavaScript 对象数组?
var postArray= new Array(); var temp = new Object(); temp.id='1'; temp.name='test'; postArray.push(t ...
- Linux内核的基本概念
Linux内核学习,推荐的书籍: <linux设备驱动开发详解第二版>.<Linux内核设计与实现第三版>.<嵌入式Linux应用开发完全手册> 第一篇:讲解Lin ...