前言

题目链接:洛谷SPOJHydro & bzoj

题意简述

有一个长度为 \(n\) 的序列,每个位置值的范围为 \([L_i, R_i]\) 内,求原序列可能的最长不降子串长度。

题目分析

尝试找一些性质。发现,连续一段合法的区间,都能分成若干真正参与最长不降子串,以及紧跟着的若干包含 \(L_i\) 的位置。下图红色表示前者,黑色表示后者。

我们把右端点向右移动,左端点肯定不会向左移动,是一个双指针。我们记 \(l\) 是当前左端点,现在让 \(r \gets r + 1\),看看左端点如何变化。发现不够,还要记 \(lst\) 表示上一个出现红色段的位置。那么分为以下几个情况讨论。

  1. \(L_r \leq L_{lst} \leq R_r\):

    说明这是一个黑色段,不需要任何操作。
  2. \(L_r \geq L_{lst}\):

    说明遇到了一个新的红色段,贡献了最长不降子串,让 \(lst \gets r\)。
  3. 此时必有 \(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 题解的更多相关文章

  1. BZOJ2276: [Poi2011]Temperature

    2276: [Poi2011]Temperature Time Limit: 20 Sec  Memory Limit: 32 MBSubmit: 293  Solved: 117[Submit][S ...

  2. Tsinghua 2018 DSA PA2简要题解

    反正没时间写,先把简要题解(嘴巴A题)都给他写了记录一下. upd:任务倒是完成了,我也自闭了. CST2018 2-1 Meteorites: 乘法版的石子合并,堆 + 高精度. 写起来有点烦貌似. ...

  3. POI2011题解

    POI2011题解 2214先咕一会... [BZOJ2212][POI2011]Tree Rotations 线段树合并模板题. #include<cstdio> #include< ...

  4. Codeforces Round #470 Div. 2题解

    A. Protect Sheep time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  5. BZOJ 2276: [Poi2011]Temperature 单调队列

    Code: #include<bits/stdc++.h> #define maxn 3000000 using namespace std; void setIO(string s) { ...

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

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

  7. noip2016十连测题解

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

  8. [LeetCode] Rising Temperature 上升温度

    Given a Weather table, write a SQL query to find all dates' Ids with higher temperature compared to ...

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

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

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

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

随机推荐

  1. maven和gradle环境变量配置及idea相关的设置

    1.maven 环境变量添加之后,重新打开cmd窗口,验证是否配置成功. idea   File >> Settings idea配置之后的验证: 2.gradle 环境变量添加之后,重新 ...

  2. Excel Wps 透视表去重计数方法

    Excel Wps 透视表去重计数方法 在处理表格,遇到处理根据某个列去重后统计数量,而不是仅仅统计数量.在网上查找资料,不确定EXCEL或者WPS某个版本可以支持该功能的实现. 折中的方案,分两步来 ...

  3. [笔记]Git常用命令大全

    Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解` [笔记]Git常用命令大全 日期:2018-6-16 阿珏 ...

  4. js-文件读写和上传下载的简单例子01

    现下,网络越来越快,浏览器的功能和性能越来越好,所以很多时候,已经不需要一些复杂的框架来实现不是非常复杂的功能. 我们只有在以下情况才会考虑使用框架或者现成的第三方组件: 1.功能复杂,自己写没有必要 ...

  5. 01-Linux系统介绍、安装与入门

    关于Linux 背景 最先出现的是Unix操作系统,这种操作系统收费,而且适用于大型机上面. Linus想做一个免费的,传播自由的操作系统.他就仿照Unix的操作,做了一个类Unix系统:Linux内 ...

  6. Nginx+Fail2ban 实现同一ip在一分钟内连续三次请求同一接口并响应成功时进行封禁

    1. 安装 Fail2Ban 和 Nginx 如果尚未安装 Fail2Ban 和 Nginx,可以使用以下命令进行安装: # CentOS默认的仓库中可能不包含Nginx,所以需要添加EPEL(Ext ...

  7. CF1800E 题解

    发现一个神奇的事实:显然不限制交换次数可以实现交换任意字符. 因此可以直接判断字符集是否相等. 在考虑哪些地方可以交换. 根据题意可知可以交换的区间为 \([1,n - k]\) 以及 \([k + ...

  8. MFC CFileDialog DoModal()无法弹出窗口,直接返回IDCANCEL

    最近需要用VS2017在MFC中加一个文件浏览窗口,采用了如下方式 1 CFileDialog Dlg(TRUE); 2 int res = Dlg.DoModal(); 3 if(res == ID ...

  9. ChatGPT学习之旅 (8) 单元测试助手

    大家好,我是Edison. 本篇我们基于上一篇的基础,来写一个单元测试助手的prompt,让它帮我们写一些我们.NET开发者不太愿意编写的单元测试代码,进而提高我们的代码质量,同时还降低我们的开发工作 ...

  10. git使用教程及常用命令

    1.初次本地git连接远程仓库,并提交代码到远程仓库 第一步 码云上创建仓库 第二步 在需要上传的项目处右键-->git bush here 第三步  初始化本地git库 git init 设定 ...