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. oracle创建默认表空间---重要

    当oracle创建数据库后,sys创建用户时还要有默认表空间.不创建默认表空间在导如项目时会有些数据表导入不成功! 由于时间仓促以截屏为例  之后会在刚刚那个空文件生成一个文件 ----------- ...

  2. 洛谷P5398 [Ynoi2018]GOSICK(二次离线莫队)

    题面 传送门 题解 维包一生推 首先请确保您会二次离线莫队 那么我们现在的问题就是怎么转移了,对于\(i\)和前缀\([1,r]\)的贡献,我们拆成\(b_i\)和\(c_i\)两部分,其中\(b_i ...

  3. 2017青岛网络赛1011 A Cubic number and A Cubic Number

    A Cubic number and A Cubic Number Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 65535/3276 ...

  4. UC浏览器中,设置了position: fixed 的元素会遮挡z-index值更高的同辈元素

    "UC浏览器中,设置了position: fixed 的元素会遮挡z-index值更高的同辈元素(非fixed)." 我们使用的artDialog弹窗中,在UC浏览器中,如果页面高 ...

  5. jboss项目设置域名

    1.在jboss-web.xml中添加<virtual-host>www.ceshi.com</virtual-host> <jboss-web> <cont ...

  6. mongo 3.4分片集群系列之三:搭建分片集群--哈希分片 + 安全

    这个系列大致想跟大家分享以下篇章: 1.mongo 3.4分片集群系列之一:浅谈分片集群 2.mongo 3.4分片集群系列之二:搭建分片集群--哈希分片 3.mongo 3.4分片集群系列之三:搭建 ...

  7. MySQL详解(18)-----------分页方法总结

    ---方法1: 直接使用数据库提供的SQL语句---语句样式: MySQL中,可用如下方法: SELECT * FROM 表名称 LIMIT M,N---适应场景: 适用于数据量较少的情况(元组百/千 ...

  8. Windows sever 2003 IIS6.0 搭建DVWA

    DVWA 环境: Windows Sever 2003 IIS 6.0+MYSQL+PHP5.4+FASFCGI 详细教程: http://files.cnblogs.com/files/yyx001 ...

  9. SpringBoot开源项目学习总结

    一.实现日期格式数据类型的转换 首先,定义DateConverter实现Converter<String, Date>接口: package com.stevlu.common; impo ...

  10. centos7安装个人博客wordpress

    第一步: 安装apache web 第二步: 安装MariaDB数据库 第三步: 安装PHP 第四步: 安装phpMyAdmin 第五部: 创建数据库: 第六部: 下载wordpress 第七部:复制 ...