hdu5141 线段树
这题说的是给了一串然后计算出这个串的最长递增子序列的长度,然后计算出有过少个子串[i,j] 他们的最长递增子序列和这整个子串的最长递增子序列相同,我们对于每个j最长递增子序列找出他在序列中的使成为最长序列的起始点,如果这个样的点存在多个那么尽量的选取靠右的,这样我们将他们离散后,然后每个线段的叶节点保存这个点的最高排位数是多少和形成他最高排位的最右端点,然后用线段树去维护这个序列, 因为知道优先会让这个点取最高位在选左区间的,这样我们只要枚举每个上升序列长度为LIS的最小区间就好了
#include <cstdio>
#include <string.h>
#include <algorithm>
#include <iostream>
using namespace std;
const int maxn = ;
typedef long long ll;
int cL, cR, cH, cloc, op;
struct Itree{
int H[maxn*],loc[maxn*];
void build(int o, int L, int R){
memset(H,,sizeof(H));
memset(loc,,sizeof(loc));
}
void query(int o, int L, int R){
if(cL<=L&&R<=cR){
if(op==){
op=;
cH=H[o];
cloc=loc[o];
}else {
if( H[o] > cH || ( H[o] == cH &&loc[o]>cloc)){
cH=H[o]; cloc=loc[o];
}
}
return ;
}
int mid=(L+R)>>;
if(cL<=mid) query(o*,L,mid);
if(cR>mid) query(o*+,mid+,R);
}
void maintain(int o){
if(H[o*]>H[o*+]||(H[o*] == H[o*+] && loc[o*] > loc[o*+] ) ){
H[o]=H[o*]; loc[o]=loc[o*];
}else{
H[o]=H[o*+] ; loc[o]=loc[o*+];
}
}
void update(int o , int L, int R){
if(L==R){
// if(cH>H[o]||(cH==H[o]&&cloc>loc[o])){
H[o]=cH;loc[o]=cloc;
//}
return ;
}
int mid = (L+R)>>;
if(op <= mid) update( o * , L , mid );
else update( o * + , mid + , R );
maintain(o);
}
}T;
int H[maxn];
int Loc[maxn];
struct seg{
int L, R,d; }P[maxn];
int main()
{
int n;
while(scanf("%d",&n)==){
for(int i=; i<n; ++i) {
scanf("%d",&H[i]);
Loc[i]=H[i];
}
sort(Loc,Loc+n);
int num=unique(Loc,Loc+n)-Loc;
for( int i = ; i < n; ++ i )
H[i] = lower_bound(Loc,Loc+num,H[i])-Loc+;
int ge=;
T.build(,,num);
int g=;
for(int i=; i<n; ++i){
op=;
cL=; cR=H[i]-;
T.query(,,num);
cH++;
if( cH == ){
cloc = i;
}
P[g].L=cloc; P[g].R=i;P[g].d=cH; g++;
ge=max(ge,cH);
op=H[i];
T.update(,,num);
}
ll ans=,L=n;
for(int i=g-; i>=; --i)
if(P[i].d==ge){
ans += (P[i].L+)*(L-P[i].R);
L=P[i].R;
}
printf("%I64d\n",ans);
}
return ;
}
hdu5141 线段树的更多相关文章
- bzoj3932--可持久化线段树
题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...
- codevs 1082 线段树练习 3(区间维护)
codevs 1082 线段树练习 3 时间限制: 3 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...
- codevs 1576 最长上升子序列的线段树优化
题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...
- codevs 1080 线段树点修改
先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...
- codevs 1082 线段树区间求和
codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...
- PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树
#44. [HNSDFZ2016 #6]可持久化线段树 统计 描述 提交 自定义测试 题目描述 现有一序列 AA.您需要写一棵可持久化线段树,以实现如下操作: A v p x:对于版本v的序列,给 A ...
- CF719E(线段树+矩阵快速幂)
题意:给你一个数列a,a[i]表示斐波那契数列的下标为a[i],求区间对应斐波那契数列数字的和,还要求能够维护对区间内所有下标加d的操作 分析:线段树 线段树的每个节点表示(f[i],f[i-1])这 ...
- 【BZOJ-3779】重组病毒 LinkCutTree + 线段树 + DFS序
3779: 重组病毒 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 224 Solved: 95[Submit][Status][Discuss] ...
- 【BZOJ-3673&3674】可持久化并查集 可持久化线段树 + 并查集
3673: 可持久化并查集 by zky Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 1878 Solved: 846[Submit][Status ...
随机推荐
- 【RF库Collections测试】Remove From Dictionary
Name:Remove From DictionarySource:Collections <test library>Arguments:[ dictionary | *keys ]Re ...
- (一)微信小程序之模拟调用后台接口踩过的坑
如下图标记的三个点 在调试过程中出现问题,特此记录. 1. 之前在浏览器测试接口习惯省略 http:// ,是因为浏览器默认有一个检测,在你输入的网址前面加http://,如果有就不加. 然而在微信小 ...
- 【VUE】Mac下vue 开发环境搭建,以及目录结构
1 安装Node.js 参看 node.js环境安装 http://www.cnblogs.com/richerdyoung/p/7265786.html 2 安装淘宝镜像 npm install ...
- JavaWeb温习之HttpServletResquest对象
HttpServletRequest对象代表客户端的请求,当客户端通过HTTP协议访问服务器时,HTTP请求头中的所有信息都封装在这个对象中,通过这个对象提供的方法,可以获得客户端请求的所有信息. 1 ...
- 超级小的web手势库AlloyFinger
针对多点触控设备编程的Web手势组件,快速帮助你的web程序增加手势支持,也不用再担心click 300ms的延迟了.拥有两个版本,无依赖的独立版和react版本.除了Dom对象,也可监听Canvas ...
- [Music] Billboard Hot 100 Singles Chart 27th Jun 2015
01 Wiz Khalifa - See You Again (Feat. Charlie P..> 30-Jul-2015 09:12 9247814 02 Taylor Swift - Ba ...
- ios ASIHTTPRequest类库简介和使用说明
官方网站: http://allseeing-i.com/ASIHTTPRequest/ .可以从上面下载到最新源码,以及获取到相关的资料. 使用iOS SDK中的HTTP网络请求API,相当的复杂, ...
- 微信小程序 --- 文件的上传和下载
文件上传 / 文件下载 : wx.uploadFile
- 【事件流】浅谈事件冒泡&&事件捕获------【巷子】
首先在扯淡的时候我们需要先了解一个东西,这个东西就是事件流. 1.什么是事件流? 解释:当一个HTML元素触发一个事件处理函数的时候,该事件会在该元素节点到根节点之间传播,传播路径所经过的节点都会接受 ...
- SVN创建主干,分支、合并分支
1.创建主干(trunk) 本文承接上文部分内容:http://www.cnblogs.com/dadonggg/p/8383696.html:部分不明,可以访问这篇文章. 当我们创建完代码仓库后,创 ...