【HDOJ】3308 LCIS
线段树,题目感觉比较难,看别人思路做的。还得继续练这个专题。
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std; #define MAXN 100005
#define lson l, mid, rt<<1
#define rson mid+1, r, rt<<1|1 int str[MAXN<<], lstr[MAXN<<], rstr[MAXN<<];
int nums[MAXN]; inline int mymax(int a, int b) {
return (a>b) ? a:b;
} inline int mymin(int a, int b) {
return (a<b) ? a:b;
} void PushUP(int l, int r, int rt) {
int mid; str[rt] = mymax(str[rt<<], str[rt<<|]);
lstr[rt] = lstr[rt<<];
rstr[rt] = rstr[rt<<|]; mid = (l+r)>>;
if (nums[mid] < nums[mid+]) {
if (lstr[rt] == mid-l+)
lstr[rt] += lstr[rt<<|];
if (rstr[rt] == r-mid)
rstr[rt] += rstr[rt<<];
str[rt] = mymax(str[rt], lstr[rt<<|]+rstr[rt<<]);
}
} void build(int l, int r, int rt) {
int mid;
if (l == r) {
str[rt] = lstr[rt] = rstr[rt] = ;
return ;
}
mid = (l+r)>>;
build(lson);
build(rson);
PushUP(l, r, rt);
} void update(int x, int c, int l, int r, int rt) {
int mid;
if (l == r) {
nums[x] = c;
return ;
}
mid = (l+r)>>;
if (x <= mid)
update(x, c, lson);
else
update(x, c, rson);
PushUP(l, r, rt);
} int query(int ll, int rr, int l, int r, int rt) {
int mid, ret = ;
if (ll<=l && rr>=r)
return str[rt]; mid = (l+r)>>;
if (ll <= mid)
ret = mymax(ret, query(ll,rr,lson));
if (rr > mid)
ret = mymax(ret, query(ll,rr,rson)); if (ll<=mid && mid<rr && nums[mid]<nums[mid+]) {
ret = mymax(ret, mymin(mid-ll+,rstr[rt<<])+mymin(lstr[rt<<|],rr-mid));
} return ret;
} void output(int beg, int end) {
int i;
for (i=beg; i<end; ++i)
printf("\t%d: l=%d,s=%d,w=%d\n", i, lstr[i], rstr[i], str[i]);
} int main() {
int case_n, n, m;
int i, x, y;
char cmd[]; scanf("%d", &case_n); while (case_n--) {
scanf("%d %d", &n, &m);
for (i=; i<n; ++i)
scanf("%d", &nums[i]);
build(, n-, );
while (m--) {
scanf("%s %d %d", cmd, &x, &y);
if (cmd[] == 'Q') {
printf("%d\n", query(x,y,,n-,));
} else {
update(x, y, , n-, );
}
//output(1, 18);
}
} return ;
}
【HDOJ】3308 LCIS的更多相关文章
- 【HDOJ】4729 An Easy Problem for Elfness
其实是求树上的路径间的数据第K大的题目.果断主席树 + LCA.初始流量是这条路径上的最小值.若a<=b,显然直接为s->t建立pipe可以使流量最优:否则,对[0, 10**4]二分得到 ...
- HDOJ 题目3308 LCIS(线段树,区间查询,区间合并)
LCIS Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- 【HDOJ】【3506】Monkey Party
DP/四边形不等式 裸题环形石子合并…… 拆环为链即可 //HDOJ 3506 #include<cmath> #include<vector> #include<cst ...
- 【HDOJ】【3516】Tree Construction
DP/四边形不等式 这题跟石子合并有点像…… dp[i][j]为将第 i 个点开始的 j 个点合并的最小代价. 易知有 dp[i][j]=min{dp[i][j] , dp[i][k-i+1]+dp[ ...
- 【HDOJ】【3480】Division
DP/四边形不等式 要求将一个可重集S分成M个子集,求子集的极差的平方和最小是多少…… 首先我们先将这N个数排序,容易想到每个自己都对应着这个有序数组中的一段……而不会是互相穿插着= =因为交换一下明 ...
- 【HDOJ】【2829】Lawrence
DP/四边形不等式 做过POJ 1739 邮局那道题后就很容易写出动规方程: dp[i][j]=min{dp[i-1][k]+w[k+1][j]}(表示前 j 个点分成 i 块的最小代价) $w(l, ...
- 【HDOJ】【3415】Max Sum of Max-K-sub-sequence
DP/单调队列优化 呃……环形链求最大k子段和. 首先拆环为链求前缀和…… 然后单调队列吧<_<,裸题没啥好说的…… WA:为毛手写队列就会挂,必须用STL的deque?(写挂自己弱……s ...
- 【HDOJ】【3530】Subsequence
DP/单调队列优化 题解:http://www.cnblogs.com/yymore/archive/2011/06/22/2087553.html 引用: 首先我们要明确几件事情 1.假设我们现在知 ...
- 【HDOJ】【3068】最长回文
Manacher算法 Manacher模板题…… //HDOJ 3068 #include<cstdio> #include<cstring> #include<cstd ...
随机推荐
- Java中的I/O流
import java.io.*//生成代表输入流的对象fis=new FileInputStream("e:/src/from.txt") //生成代表输出流的对象 fos=ne ...
- 错误:Retrieving the COM class factory for component with CLSID {000209FF-0000-0000-C000-000000000046} failed due to the following error: 80070005 拒绝访问。
最近,把一个网站部署到另一个服务器上,网站中一个功能word转pdf报下面错误: 在此附上解决方案: 方法1:配置Web.Config文件,在每次请求时模拟本地系统的账户. 具体操作:在Web.Con ...
- Android工程师必会做的20道题
一.单选题 (共7道题,每题5分) 1.使用AIDL完成远程service方法调用下列说法不正确的是 A.aidl对应的接口名称不能与aidl文件名相同 B.aidl的文件的内容类似java代 ...
- Android - 折线图
使用Android的canvas,画折线图:代码为: package spt.view; import android.annotation.SuppressLint; import android. ...
- latch:cache buffers chains的优化思路
数据块在buffer cache存放是以linked list方式存放的.当一个session想要访问/修改buffer cache的block,首先需要通过hash算法检查该block是否存在于bu ...
- MyBatis的学习总结六:Mybatis的缓存【参考】
一.Mybatis缓存介绍 正如大多数持久层框架一样,Mybatis同样提供了一级缓存和二级缓存 1.一级缓存:基于PerpetualCache的HashMap本地缓存,其存储作用域为Session, ...
- jQuery分析(2) - $工厂函数分析
前言 从这节进入jQuery的世界,首先从jQuery的入口函数开始了解jQuery()或$是如何运作的,这里我给出了一个最小的例子来分析. 回忆 在进入分析代码前我们回想下jQuery的使用方法有哪 ...
- web页面的优化
众所周知,一个web页面通常会包括HTML(XHTML.XML).CSS.Javascript,而其中HTML(XHTML.XML)为结构化语言,用于构建页面结构和相关数据:CSS则负责页面的样式,即 ...
- 洛谷 U2878 小R的分数比赛(fraction)
题目提供者 2015c07 标签 数论(数学相关) 高精度 难度 尚无评定 通过/提交 0/29 提交该题 记录 题目背景 P5难度系数:★★★☆☆ 小R再次挑战你. 这次的挑战又会是什么呢? 题目描 ...
- 利用XPath解析带有xmlns的XML文件
在.net中,编写读取xml 的程序中提示"未将对象引用设置到对象的实例",当时一看觉得有点奇怪.为什么在读取xml数据的时候也要实例化一个对象.google了才知道,xml文件中 ...