大概评级:绿。

一看到这种题目,就知道肯定是数据结构题,我们首先用一个众所周知的二分来求出 \(pos\) 数组,\(pos_i\) 表示以 \(i\) 结尾的最长上升子序列的大小,然后将询问离线,弄一个 vector,命名 \(s\),把询问中每个 \(R_i\) 为 \(i(1 \le i \le n)\) 的询问存进 \(s_i\) 中,然后遍历每个 \(i(1 \le i \le n)\),每次先修改动态开点权值线段树上的点 \(a_i\),将它改为 \(pos_i\),然后遍历 \(s_i\),将 \(s_i\) 中存储的询问全部拿出来,然后查询即可。

总时间复杂度:\(O(n+n \log n+q+q \log q) = O(n \log n+q \log q)\)。

代码:

#include<bits/stdc++.h>
using namespace std;
const int N = 1e7+5;
int a[N];
int low[N];
int pos[N];
struct node
{
int l;
int r;
int ls;
int rs;
int maxx;
}t[N];
struct node1
{
int x;
int y;
};
vector<node1>e[N];
int cnt;
void update(int &rt,int l,int r,int x,int v)
{
if(!rt)
{
rt = ++cnt;
t[rt].l = l;
t[rt].r = r;
}
if(t[rt].l == t[rt].r)
{
t[rt].maxx = max(t[rt].maxx,v);
return;
}
int mid = t[rt].l+t[rt].r>>1;
if(x<=mid)
{
update(t[rt].ls,l,mid,x,v);
}
else
{
update(t[rt].rs,mid+1,r,x,v);
}
t[rt].maxx = max(t[t[rt].ls].maxx,t[t[rt].rs].maxx);
}
int query(int rt,int l,int r)
{
if(!rt)
{
return 0;
}
if(l<=t[rt].l&&t[rt].r<=r)
{
return t[rt].maxx;
}
int mid = t[rt].l+t[rt].r>>1,maxx = 0;
if(l<=mid)
{
maxx = max(maxx,query(t[rt].ls,l,r));
}
if(r>mid)
{
maxx = max(maxx,query(t[rt].rs,l,r));
}
return maxx;
}
int ans[N];
signed main()
{
int n,_,o = 0;
scanf("%d %d",&n,&_);
for(int i = 1;i<=n;i++)
{
scanf("%d",&a[i]);
}
int id = 0;
for(int i = 1;i<=n;i++)
{
if(a[i]>low[id])
{
low[++id] = a[i];
pos[i] = id;
}
else
{
int poss = lower_bound(low+1,low+id+1,a[i])-low;
low[poss] = a[i];
pos[i] = poss;
}
}
for(int i = 1;i<=_;i++)
{
int x,y;
scanf("%d %d",&x,&y);
e[x].push_back({i,y});
}
for(int i = 1;i<=n;i++)
{
update(o,1,1e9,a[i],pos[i]);
for(auto it:e[i])
{
ans[it.x] = query(o,1,it.y);
}
}
for(int i = 1;i<=_;i++)
{
printf("%d\n",ans[i]);
}
return 0;
}

总结:这道题的精髓在于将询问离线。

ABC393F题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

  10. JSOI2016R3 瞎BB题解

    题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...

随机推荐

  1. Redis应用—6.热key探测设计与实践

    大纲 1.热key引发的巨大风险 2.以往热key问题怎么解决 3.热key进内存后的优势 4.热key探测关键指标 5.热key探测框架JdHotkey的简介 6.热key探测框架JdHotkey的 ...

  2. postgres

    10.67 su - app  docker pull postgres:12.15  docker run -d --name pgsql12 -p 5432:5432 -e "POSTG ...

  3. Qt数据库应用2-数据导出到xls

    一.前言 导入导出数据到csv由于语法简单,适用场景有限,于是乎还是必须再造一个轮子导出数据到xls,在经历过数十年的项目实战经验中不断调整和优化.尤其记得当初第一个版本v0.01大概在2011年左右 ...

  4. Windows7-64环境中部署OpenLayers6.4.3详细步骤

    注意:OL5以后,OpenLayers采用ES6,以前OL4那种简单的加库的方法已经不适用了. Windows7-64环境中部署OpenLayers6.4.3详细步骤: 1.官方教程(英文版) 2.中 ...

  5. C# Unit test TestInitialize\TestCleanp

    C# TestInitialize\TestCleanp ※※冰馨※※ 2020-12-15 09:19:37 75 收藏分类专栏: VS版权 VS专栏收录该内容197 篇文章1 订阅订阅专栏带有[C ...

  6. 前端(三)-JavaScript

    1.基本语法 1.1 引入JavaScript 1.1.1行内引入 <input type="button" value="轻轻点我一下" onclick ...

  7. kubernetes 使用ceph实现动态持久卷存储

    k8s使用ceph存储 ceph提供底层存储功能,cephfs方式支持k8s的pv的3种访问模式​​ReadWriteOnce,ReadOnlyMany ,ReadWriteMany​​​ ,RBD支 ...

  8. canal源码分析简介-3

    5.0 store模块  2018-10-08 23:14:58  8,328 7 1 store模块简介 store模块用于binlog事件的存储 ,目前开源的版本中仅实现了Memory内存模式.官 ...

  9. bullyBox pg walkthrough Intermediate

    nmap 发现80 和 22端口 访问80 端口发现 跳转 http://bullybox.local/ 在/etc/hosts 里面加上这个域名 dirsearch 扫描的时候发现了.git泄露 用 ...

  10. .NET9 AOT部署

    概念 AOT是Ahead-of-Time的缩写,AOT是将C#程序提前编译为机器代码(通常为平台特定的二进制文件),在应用程序启动之前完成编译过程. 微软官方文档是这样说的 将应用程序发布为本机 AO ...