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 ...
随机推荐
- 金融系列4《PUTKEY指令》
用一个新的密钥替换一个已经存在的密钥:新密钥可以有与被替换的密钥相同的或不同的密钥版本号,但是必须与被替换的密钥有相同的密钥标识符. 用新密钥替换多个已经存在的密钥:新密钥可以有与被替换的密钥相同的或 ...
- C# 反射学习总结
C#中的反射可以使得程序集和类型(类.结构.委托.接口和枚举)以及类型中的成员(方法.字段.属性.事件.参数.构造函数等)都成为变量在编程中动态调用.
- .NET基础之:i++和i=i+1和++i的区别
i++ 一定等同于 i=i+1吗? 大家都知道,i++通常情况都是等同于i=i+1,在编译时,clr会自动向上转换 比如说 int t =1; t++; 等同于 t=t+1; //1 是 ...
- verilog逻辑复制
本文转自:http://www.cnblogs.com/linjie-swust/archive/2012/03/27/FPGA_verilog.html 在FPGA设计中经常使用到逻辑复制,逻辑复制 ...
- ZOJ 3229 有上下界最大流
1: /** 2: ZOJ 3229 有上下界的最大流 3: 两次求最大流的过程,非二分 4: 有源汇上下界的最大流问题, 首先连接 sink -> src, [0,INF]. 5: 根据net ...
- nodejs Q.js promise
var Q = require("q"); documentation for Qhttps://github.com/kriskowal/qhttps://github.com/ ...
- LintCode-Kth Prime Number.
Design an algorithm to find the kth number such that the only prime factors are 3, 5, and 7. The eli ...
- iOS关于CGContextSetBlendMode: invalid context 0x0的错误
在ios 7的模拟器中,选择一个输入框准备输入时,会触发这个错误,以下是出错详细日志: <Error>: CGContextSetBlendMode: invalid context 0x ...
- iOS 计算 日期 距离 当前 系统的日期 相差 多少
#pragma mark - 时间计算函数 - (NSTimeInterval)intervalSinceNow:(NSString *) theDate { NSDateFormatter * da ...
- adb 选择设备
在adb中有多个设备时,可以先adb devices列举出设备,然后可以通过adb -s <设备名> [其他参数] 对某个设备进行操作. 例如: adb -s 0123456789ABC ...