http://acm.hdu.edu.cn/showproblem.php?pid=3308

题意: 两个操作  : 1 修改 单点  a 处的值。

2 求出 区间【a,b】内的最长上升子序列。

做法:线段树区间合并。了解线段树的具体含义很容易。

 1 // by caonima
 2 // hehe
 3 #include <cstdio>
 4 #include <cstring>
 5 #include <algorithm>
 6 #include <vector>
 7 #include <cmath>
 8 using namespace std;
 9 const int MAX= 1e5+;
 int Lsum[MAX<<],Rsum[MAX<<],Msum[MAX<<];
 int Lnum[MAX<<],Rnum[MAX<<];
 int a[MAX];
 char Q[];
 
 void push_up(int o,int m) {
     Lsum[o]=Lsum[o<<];
     Rsum[o]=Rsum[o<<|];
     Msum[o]=max(Msum[o<<],Msum[o<<|]);
     Lnum[o]=Lnum[o<<];
     Rnum[o]=Rnum[o<<|];
     if(Rnum[o<<]<Lnum[o<<|]) {
         if(Lsum[o<<]==(m-(m>>))) Lsum[o]+=Lsum[o<<|];
         if(Rsum[o<<|]==(m>>)) Rsum[o]+=Rsum[o<<];
         Msum[o]=max(Msum[o],Rsum[o<<]+Lsum[o<<|]);
     }
     return ;
 }
 
 void build(int L,int R,int o) {
     if(L==R) {
         Lsum[o]=Rsum[o]=Msum[o]=;
         Lnum[o]=Rnum[o]=a[L];
         return ;
     }
     int mid=(L+R)>>;
     build(L,mid,o<<);
     build(mid+,R,o<<|);
     push_up(o,R-L+);
 }
 
 void Update(int L,int R,int o,int k,int val) {
     if(L==R) {
         Lnum[o]=Rnum[o]=val;
       //  Lsum[o]=Rsum[o]=Msum[o]=1;
         return ;
     }
     int mid=(L+R)>>;
     if(k<=mid) Update(L,mid,o<<,k,val);
     else Update(mid+,R,o<<|,k,val);
     push_up(o,R-L+);
 }
 
 int Query(int L,int R,int o,int ls,int rs) {
     if(ls<=L&&rs>=R) {
         return Msum[o];
     }
     int mid=(L+R)>>;
     int ans=;
     if(ls<=mid) ans=max(ans,Query(L,mid,o<<,ls,rs));
     if(rs>mid) ans=max(ans,Query(mid+,R,o<<|,ls,rs));
     if(Rnum[o<<]<Lnum[o<<|])
     ans=max(ans,min(mid-ls+,Rsum[o<<])+min(rs-mid,Lsum[o<<|]));
     return ans;
 }
 
 int main() {
     int cas,n,m,ls,rs;
     scanf("%d",&cas);
     while(cas--) {
         scanf("%d %d",&n,&m);
         for(int i=;i<=n;i++) scanf("%d",&a[i]);
         build(,n,);
         for(int i=;i<=m;i++) {
             scanf("%s %d %d",Q,&ls,&rs);
             if(Q[]=='Q') {
                 int res=Query(,n,,ls+,rs+);
                 printf("%d\n",res);
             }
             else {
                 Update(,n,,ls+,rs);
             }
         }
     }
     return ;

85 }

HDU 3308 (线段树区间合并)的更多相关文章

  1. hdu 3308(线段树区间合并)

    LCIS Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  2. hdu 3308 线段树 区间合并+单点更新+区间查询

    LCIS Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  3. HDU 3911 线段树区间合并、异或取反操作

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=3911 线段树区间合并的题目,解释一下代码中声明数组的作用: m1是区间内连续1的最长长度,m0是区间内连续 ...

  4. HDU 3911 线段树区间合并

    北京赛区快了,准备袭击数据结构和图论.倒计时 18天,线段树区间合并.维护一个最长连续.. 题意:给一个01串,以下有一些操作,问区间最长的连续的1的个数 思路:非常裸的线段树区间合并 #includ ...

  5. hdu 1806(线段树区间合并)

    Frequent values Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  6. HDU 3308 LCIS (线段树区间合并)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3308 题目很好懂,就是单点更新,然后求区间的最长上升子序列. 线段树区间合并问题,注意合并的条件是a[ ...

  7. LCIS HDU - 3308 (线段树区间合并)

    LCIS HDU - 3308 Given n integers. You have two operations: U A B: replace the Ath number by B. (inde ...

  8. HDU 3308 LCIS (经典区间合并)【线段树】

    <题目链接> 题目大意: 给你一段序列,对其进行两种操作,一是修改某个序号的点的值:二是查询某个区间的LCIS(最长上升子序列). 解题分析: 线段树区间合并的典型例题,用求某个区间的LC ...

  9. hdu 3911 Black And White (线段树 区间合并)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3911 题意: 给你一段01序列,有两个操作: 1.区间异或,2.询问区间最长的连续的1得长度 思路: ...

随机推荐

  1. java虚拟机全集(31篇文章)

    深入理解java虚拟机系列 深入理解Java虚拟机笔记---内存区域 深入理解Java虚拟机笔记---判断对象是否存活 深入理解Java虚拟机笔记---垃圾收集算法 深入理解Java虚拟机笔记---垃 ...

  2. Android 性能优化(4)Optimizing Layout Hierarchies:用Hierarchy Viewer和Layoutopt优化布局

    Optimizing Layout Hierarchies This lesson teaches you to Inspect Your Layout Revise Your Layout Use ...

  3. 全面学习ORACLE Scheduler特性(11)使用Job Classes

    六.使用Job Classes Job Classes 相当于创建了一个job组,DBA可以将那些具有相同特性的job,统统放到相同的Job Classes中,然后通过对Job Class应用ORAC ...

  4. 纵横填字js

    新数据结构设计: 定义一个map: key是横纵坐标字符串,比如“0,4” value是一个json,包含以下属性:字,横向的词(若 有的话,无的话,空串),纵向的词(若有的话,无的话,空串). 另有 ...

  5. php函数的声明与使用

    function 函数名(){ 函数体 } 一个函数是由3部分组成:声明(function 关键字).函数名(用来找到函数体的).函数体(封装的代码) 2.函数的优越性 代码重用性强.维护方便.提高开 ...

  6. arp学习笔记(linux高性能服务编程)

    先看看arp的定义吧 现在linux运行这条命令 tcpdump -i eth0:1 -ent '(dst 192.168.5.190 and src 192.168.5.109)or( dst 19 ...

  7. Microsoft SQL Server学习(五)--操作符聚合函数

    算术运算符 逻辑运算符 比较运算符 聚合函数 算术运算符(+ - * / ) select score*2 as 成绩翻倍 from class_A update class_A set score= ...

  8. postgresql遇到的性能问题

    问题SQL scwksmlcls.wk_cls_c , scwklrgcls.wk_lrg_cls_nm , scwkmdlcls.wk_mdl_cls_nm , scwksmlcls.wk_sml_ ...

  9. CMD命令行提示被禁用的情况下如何继续使用命令行工具执行命令

    1.直接在Windows搜索 左下 输入要执行的 CMD 命令单句.多句同时执行没有试出来. 暂时记录这一条.2016-12-20

  10. arx移植 及预处理器

    来源:http://bbs.mjtd.com/thread-102486-1-1.html 另,ObjectARX编程参考:http://bbs.mjtd.com/forum-14-1.html 如果 ...