HDU 3308 线段树 最长连续上升子序列 单点更新 区间查询
题意:
T个测试数据
n个数 q个查询
n个数 ( 下标从0开始)
Q u v 查询 [u, v ] 区间最长连续上升子序列
U u v 把u位置改成v
#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define N 101010
#define L(x) (x<<1)
#define R(x) (x<<1|1)
inline int Max(int a,int b){return a>b?a:b;}
inline int Min(int a,int b){return a<b?a:b;} struct node
{
int l,r;
int mid(){ return (l+r)>>1; }
int len(){ return r-l+1; }
int Llen, Rlen, maxlen; }tree[4*N];
int a[N];
void updata_up(int id){
tree[id].Llen = tree[L(id)].Llen;
tree[id].Rlen = tree[R(id)].Rlen;
tree[id].maxlen = Max( tree[L(id)].maxlen, tree[R(id)].maxlen); if( a[ tree[L(id)].r ] < a[ tree[R(id)].l ] )
{
if( tree[L(id)].Llen == tree[L(id)].len())
{
tree[id].Llen += tree[R(id)].Llen;
tree[id].maxlen = Max( tree[id].maxlen, tree[id].Llen);
}
if( tree[R(id)].Rlen == tree[R(id)].len() )
{
tree[id].Rlen += tree[L(id)].Rlen;
tree[id].maxlen = Max( tree[id].maxlen, tree[id].Rlen);
}
tree[id].maxlen = Max( tree[id].maxlen, tree[L(id)].Rlen + tree[R(id)].Llen ); } }
void build(int l, int r, int id){
tree[id].l = l, tree[id].r = r; if(l==r){ tree[id].Llen = tree[id].Rlen = tree[id].maxlen =1; return ; } int mid = (l+r)>>1;
build(l, mid, L(id));
build(mid+1, r, R(id));
updata_up(id);
} void updata(int pos,int id){
if(tree[id].l == tree[id].r)return ; int mid = tree[id].mid();
if( pos <= mid ) updata(pos, L(id));
else updata(pos, R(id));
updata_up(id);
} int query(int l, int r, int id){
if( l == tree[id].l && tree[id].r == r)
return tree[id].maxlen; int mid = tree[id].mid();
if(r <= mid)return query(l, r, L(id));
else if(mid < l) return query(l, r, R(id)); int L = query(l, mid, L(id)), R = query(mid+1, r, R(id)); if( a[mid] < a[mid+1] ){
int LL = Min( mid - l + 1, tree[L(id)].Rlen);
int RR = Min( r - mid, tree[R(id)].Llen);
return Max( Max(L,R), LL+RR);
}
else return Max(L, R);
} int main(){
int T,n,q,i; scanf("%d",&T);
while(T--){
scanf("%d %d", &n, &q);
for(i=1;i<=n;i++)scanf("%d",&a[i]); build(1, n, 1);
while(q--)
{
char c = '-';
while(c!='Q' && c!='U') c = getchar();
int u,v; scanf("%d %d", &u, &v); if(c == 'Q')
printf("%d\n", query(u+1, v+1, 1));
else if(c == 'U')
{ a[u+1] = v; updata(u+1, 1); } }
}
return 0;
}
/*
99
10 10
7 7 3 3 5 9 9 8 1 8
Q 6 6
U 3 4
Q 0 1
Q 0 5
Q 4 7
Q 3 5
Q 0 2
Q 4 6
U 6 10
Q 0 9 10 99
1 2 3 4 5 6 7 8 9 10
Q 4 7
U 0 8
Q 0 9
U 8 8 Q 0 9 */
HDU 3308 线段树 最长连续上升子序列 单点更新 区间查询的更多相关文章
- HDU 3308 线段树求区间最长连续上升子序列长度
题意:两种操作,Q L R查询L - R 的最长连续上升子序列长度,U pos val 单点修改值 #include <bits/stdc++.h> #define N 100005 us ...
- hdu 3308(线段树区间合并)
LCIS Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 3308 线段树
题目大意:给n个数,两种操作1:U a b 更新第a个为b (从0开始)2: Q a ,b 查询 a,b之间LCIS(最长连续递增子序列)的长度. Sample Input110 107 ...
- HDU 3308 线段树单点更新+区间查找最长连续子序列
LCIS Time Limit: 6000/2000 MS (Java/Oth ...
- hdu 3308 线段树,单点更新 求最长连续上升序列长度
LCIS Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 3308 线段树 区间合并+单点更新+区间查询
LCIS Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 3397 线段树双标记
Sequence operation Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdu 2871 线段树(各种操作)
Memory Control Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ...
- hdu 1166 线段树(sum+单点修改)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
随机推荐
- ActiveMQ使用记录
1.在Linux中安装ActiveMQ 官方文档地址:http://activemq.apache.org/getting-started.html#GettingStarted-StartingAc ...
- left join 过滤条件写在on后面和写在where 后面的区别
create table t1(id int, feild int);insert into t1 values(1 , 1);insert into t1 values(1 , 2);insert ...
- 【原创】书本翻页效果booklet jquery插件系列之简介
booklet jquery插件系列之简介 本文由五月雨恋提供,转载请注明出处. 一.安装 1.添加CSS和Javascript 添加booklet CSS文件到你的页面. <link rel= ...
- C++中的运算符优先级
1 () [] . ->2 ! ~ -(负号) ++ -- &(取变量地址)* (type)(强制类型) sizeof 3 * / % 4 + ...
- error: format not a string literal and no format arguments [-Werror=format-security]
You can put this in your Application.mk to disable treating those warnings as errors: APP_CFLAGS += ...
- 如何编写好的jQuery代码
本文就是自己看,如果您不小心进到了这里,请看源处,是这个作者翻译的:http://blog.sae.sina.com.cn/archives/4157 讨论jQuery和javascript性能的文章 ...
- WPF九宫格HLSL版
偶遇需要再WPF里面处理九宫格,因不喜截图缩放,即写成了HLSL的Effcect sampler2D input : register(s0); /// <summary>The floa ...
- Android开发应用异步检查更新代码
开发环境:android studio sdk 4.0及以上 场景:用户点击检查更新按钮进行检查服务器版本号,若有新版本则进行下载更新.异步检测版本号 package com.example.q ...
- 高质量的javascript代码 -- 深入理解Javascript
一. 编写高质量的javascript代码基本要点a) 可维护的代码(Writing Maintainable Code)i. 可读(注释)ii. 一致(看上去是同一个人写的)iii. 已记录b) 最 ...
- Extjs4 使用store的post方法
Extjs4 使用store的post方法 引用官网的一句话 Now when we call store.load(), the AjaxProxy springs into action, mak ...