Temperature 题解
前言
题目链接:洛谷;SPOJ;Hydro & bzoj。
题意简述
有一个长度为 \(n\) 的序列,每个位置值的范围为 \([L_i, R_i]\) 内,求原序列可能的最长不降子串长度。
题目分析
尝试找一些性质。发现,连续一段合法的区间,都能分成若干真正参与最长不降子串,以及紧跟着的若干包含 \(L_i\) 的位置。下图红色表示前者,黑色表示后者。
我们把右端点向右移动,左端点肯定不会向左移动,是一个双指针。我们记 \(l\) 是当前左端点,现在让 \(r \gets r + 1\),看看左端点如何变化。发现不够,还要记 \(lst\) 表示上一个出现红色段的位置。那么分为以下几个情况讨论。
- \(L_r \leq L_{lst} \leq R_r\):
说明这是一个黑色段,不需要任何操作。 - \(L_r \geq L_{lst}\):
说明遇到了一个新的红色段,贡献了最长不降子串,让 \(lst \gets r\)。 - 此时必有 \(R_r < L_{lst}\):
说明遇到上图绿色段的情况。我们要在 \(lst + 1 \sim r\) 里重新挑选出一个 \(l'\) 和 \(lst'\)。
前两者都很好处理,思考怎么弄第 \(3\) 条。
发现关键都在每条线段的下端,如果 \(l \sim r\) 里 \(\max L_i > R_{r}\),那么一定是不合法的,因为是不能下降的。所以考虑用 ST 表维护区间最小 \(L\) 的位置。遇到情况 \(3\),先让 \(l' \gets lst\),当 \(\max L_{l' \sim r} > R_{r}\),将 \(l' \gets l' +1\),至于 \(lst'\),就是最终 \(\max L_{l' \sim r}\) 的那个位置。
时间复杂度 \(\Theta(n \log n)\),瓶颈在于 ST 表。
继续思考,发现合法区间 \(l \sim r\) 的充要条件也是 \(\forall i \in [l, r], \max L_{l \sim i} \leq R_i\)。那么不需要那么麻烦,直接上双指针。如果 \(\max L_{l \sim r} > R_r\),\(l \gets l + 1\)。正确性显然。但是时间复杂度还是 \(\Theta(n \log n)\),能不能去掉 ST 表呢?
发现,我们要维护滑动窗口的最值,所以,上单调队列。队列里 \(L\) 从大到小排序。统计答案时,上一次弹出队列的位置 \(+ 1\) 就是合法的最长的左端点。
时空都是线性的。
代码
// #pragma GCC optimize(3)
// #pragma GCC optimize("Ofast", "inline", "-ffast-math")
// #pragma GCC target("avx", "sse2", "sse3", "sse4", "mmx")
#include <iostream>
#include <cstdio>
using namespace std;
int n, L[1000010], R[1000010];
int Q[1000010], head = 1, tail;
int ans = 1;
signed main() {
scanf("%d", &n);
for (int i = 1; i <= n; ++i) scanf("%d%d", &L[i], &R[i]);
for (int i = 1; i <= n; ++i) {
while (head <= tail && L[Q[head]] > R[i]) ++head;
if (head <= tail) ans = max(ans, i - Q[head - 1]);
while (head <= tail && L[Q[tail]] <= L[i]) --tail;
Q[++tail] = i;
}
printf("%d", ans);
return 0;
}
后记 & 反思
双指针,考虑好添加右端点后,怎么删去不合法的左端点。
Temperature 题解的更多相关文章
- BZOJ2276: [Poi2011]Temperature
2276: [Poi2011]Temperature Time Limit: 20 Sec Memory Limit: 32 MBSubmit: 293 Solved: 117[Submit][S ...
- Tsinghua 2018 DSA PA2简要题解
反正没时间写,先把简要题解(嘴巴A题)都给他写了记录一下. upd:任务倒是完成了,我也自闭了. CST2018 2-1 Meteorites: 乘法版的石子合并,堆 + 高精度. 写起来有点烦貌似. ...
- POI2011题解
POI2011题解 2214先咕一会... [BZOJ2212][POI2011]Tree Rotations 线段树合并模板题. #include<cstdio> #include< ...
- Codeforces Round #470 Div. 2题解
A. Protect Sheep time limit per test 1 second memory limit per test 256 megabytes input standard inp ...
- BZOJ 2276: [Poi2011]Temperature 单调队列
Code: #include<bits/stdc++.h> #define maxn 3000000 using namespace std; void setIO(string s) { ...
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- [LeetCode] Rising Temperature 上升温度
Given a Weather table, write a SQL query to find all dates' Ids with higher temperature compared to ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
随机推荐
- vue使用wx-open-launch-weapp
vue使用wx-open-launch-weapp 官方文档 <template> <div style="width: 100%; height: 100%;" ...
- window10设置保护眼睛的颜色
1.调出运行菜单.右击开始键选择运行,或者同时按下键盘上的WIN+R打开运行框,输入 regedit 回车转到注册表编辑器.2.选择第二项 HKEY_CURRENT_USER 点击进入.进入后点击 C ...
- 从 Docker Hub 拉取镜像受阻?这些解决方案帮你轻松应对
最近一段时间 Docker 镜像一直是 Pull 不下来的状态,感觉除了挂,想直连 Docker Hub 是几乎不可能的.更糟糕的是,很多原本可靠的国内镜像站,例如一些大厂和高校运营的,也陆续关停了, ...
- K-means聚类是一种非常流行的聚类算法
K-means聚类是一种非常流行的聚类算法,它的目标是将n个样本划分到k个簇中,使得每个样本属于与其最近的均值(即簇中心)对应的簇,从而使得簇内的方差最小化.K-means聚类算法简单.易于实现,并且 ...
- 认识.NET 日志系统
认识.NET 日志系统 基本概念 日志级别:Trace<Debug<Information<Waring<Error<Critical 日志提供者(LoggingProv ...
- 在Linux驱动中使用LED子系统
在Linux驱动中使用LED子系统 原文:https://blog.csdn.net/hanp_linux/article/details/79037684 前提配置device driver下面的L ...
- python3 安装pymssql失败 pip3 install pymssql
python3 安装pymssql失败 报错信息: AttributeError: module 'platform' has no attribute 'linux_distribution' 解决 ...
- 用StabilityMatrix一键安装Stable Diffusion
Stable Diffusion是2022年发布的深度学习文字到图像生成模型,它既能免费使用,又能部署在本地端,又有非常多的模型可以直接套用,在使用体验上比Midjourney和DALL-E更加强大. ...
- MathType选项灰色无法点击或者word无法粘贴,治本解决方案
问题描述: mathtype安装过后,word中会出现mathtype的选项,但是这时mathtype中的选项是虚的,无法点击,而且此时word无法粘贴内容. 解决步骤: 1.打开word选项,点击加 ...
- Java-Response对象设置响应消息
功能:设置响应消息 1.设置响应行 格式:HTTP/1.1 200 OK 设置状态码:setStatus(int sc) 2.设置响应头:setHeader(String name,String va ...