解题报告:Codeforces 279C Ladder
Codeforces 279C Ladder
本题与tbw这篇博客上的题有相似思路。tbw的本来我还不会,抄了题解才过,这道题好歹自己磕半天磕出来了。到tbw做那道题我突然想明白了,再一想诶跟这里不是一样的嘛,lol。然后就被他逼着过来写题解,痛得一批。
题意
对于一段序列,要求刚开始不能递减,之后不能递增。换言之,只能有一个波峰,不能有波谷,可以是一条平平的线。
俺的思路
来一个数组ndec[]
,记录某一个点之后的下降点。
再来一个数组ninc[]
,记录某一个点之后的上升点。
+-----------------+ +-----------------+
| | | * * |
| * * * | |* * * *|
| * * * *| | * * * * |
|* * | | |
+-----------------+ +-----------------+
1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9
^ ^ ^ ^ ^
d 5 5 5 5 9 9 9 9 ? i 4 4 4 5 9 9 9 9 ?
注意不管上升、下降是否连续,只要比前一点大就认为是上升点,比前一点小就认为是下降点。
并且一定要记录下一个,不要记自己。
fill0(ninc);
fill0(ndec);
forward(i,2,n){
if(a[i]>a[i-1])ninc[i]=1;
if(a[i]<a[i-1])ndec[i]=1;
}
ll tmpi = INF, tmpd = INF, flagi, flagd;
backward(i,n,1){
flagi = ninc[i];
ninc[i] = tmpi;
if(flagi==1)tmpi=i;
flagd = ndec[i];
ndec[i] = tmpd;
if(flagd==1)tmpd=i;
}
俺已经忘记这都是些什么鬼画符了……
之后怎么判断一个区间是否OK呢?
+-----------------+ +-----------------+
| | | |
| * * * | | * * *] |
| [* *]* *| | [* * * *|
|* * | |* * |
+-----------------+ +-----------------+
1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9
d ^ ^ d ^ ^
*-->* *-->*
i ^ ^ ^ i ^ ^ ^
*-->* *-->*
l r ^OK l ^ r NO
我们找l
点之后的一个下降点,即ndec[l]
。那么从l
到这玩意之前都是一段非降序列。
如果
ndec[l]
\(>\)r
,说明l
到r
之间都是非降序列,是合法的。如果
ndec[l]
\(\le\)r
,说明前半段是非降,那么就要求从ndec[l]
开始的后半段非增。直接再往后找一个上升点,即ninc[ndec[l]]
。如果
ninc[ndec[l]]
\(>\)r
,类似上面所述,是OK的。如果
ninc[ndec[l]]
\(\le\)r
,说明上升之后开始下降、结果还没出区间又开始上升了,炸裂。
好像没提到全程非升的情况?比如有a[l+1]
\(<\)a[l]
,
那样ndec[l]
\(=\)l+1
,就合并到“前半段非降”的情况(前半段指\([l,l]\))。
if(ndec[x]>y||ninc[ndec[x]]>y){
cout<<"Yes"<<endl;
}
else{
cout<<"No"<<endl;
}
查询直接干到\(O(1)\)。
代码
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef long double ld;
#define wlf(i,a,b) for(ll i=a;i<=b;++i)
#define tbw(i,a,b) for(ll i=a;i>=b;--i)
#define fill0(b) memset(b,0,sizeof(b))
#define fill1(b) memset(b,-1,sizeof(b))
#define fill3f(b) memset(b,0x3f,sizeof(b))
const ll INF = 0x3f3f3f3f3f3f3f3f;
const ll N = 1e5+10;
ll n,m,a[N],ninc[N],ndec[N];
int main(){
ios::sync_with_stdio(0);
cin.tie(0);cout.tie(0);
cin>>n>>m;
wlf(i,1,n)cin>>a[i];
fill0(ninc);
wlf(i,2,n){
if(a[i]>a[i-1])ninc[i]=1;
if(a[i]<a[i-1])ndec[i]=1;
}
ll tmpi = INF, tmpd = INF, flagi, flagd;
tbw(i,n,1){
flagi = ninc[i];
ninc[i] = tmpi;
if(flagi==1)tmpi=i;
flagd = ndec[i];
ndec[i] = tmpd;
if(flagd==1)tmpd=i;
}
while(m--){
ll x,y;
cin>>x>>y;
if(ndec[x]>y||ninc[ndec[x]]>y){
cout<<"Yes"<<endl;
}
else{
cout<<"No"<<endl;
}
}
return 0;
}
解题报告:Codeforces 279C Ladder的更多相关文章
- codeforces --- 279C Ladder
C. Ladder time limit per test 2 seconds memory limit per test 256 megabytes input standard input out ...
- Codeforces 279C - Ladder - [简单DP]
题目链接:http://codeforces.com/problemset/problem/279/C 题意: 给出 $n$ 个整数 $a[1 \sim n]$,$m$ 个查询,对于一个查询 $[l_ ...
- 寒假训练3解题报告 CodeForces #148
CodeForces 148B 一道简单模拟,判断龙能够抓到公主几次,如果公主和龙同时到达公主的城堡,不算龙抓住她,因为路程除以速度可能会产生浮点数,所以这里考虑一下精度问题 #include < ...
- CodeForces 279C Ladder (RMQ + dp)
题意:给定一个序列,每次一个询问,问某个区间是不是先增再降的. 析:首先先取处理以 i 个数向左能延伸到哪个数,向右能到哪个数,然后每次用RQM来查找最大值,分别向两边延伸,是否是覆盖区间. 代码如下 ...
- cf1189解题报告
cf1189div2解题报告 codeforces A 答案要不是一串要不就是去掉最后一个字母的两串 #include <bits/stdc++.h> #define ll long lo ...
- codeforces 476C.Dreamoon and Sums 解题报告
题目链接:http://codeforces.com/problemset/problem/476/C 题目意思:给出两个数:a 和 b,要求算出 (x/b) / (x%b) == k,其中 k 的取 ...
- Codeforces Round #378 (Div. 2) D题(data structure)解题报告
题目地址 先简单的总结一下这次CF,前两道题非常的水,可是第一题又是因为自己想的不够周到而被Hack了一次(或许也应该感谢这个hack我的人,使我没有最后在赛后测试中WA).做到C题时看到题目情况非常 ...
- Codeforces Round 665 赛后解题报告(暂A-D)
Codeforces Round 665 赛后解题报告 A. Distance and Axis 我们设 \(B\) 点 坐标为 \(x(x\leq n)\).由题意我们知道 \[\mid(n-x)- ...
- Codeforces Round 662 赛后解题报告(A-E2)
Codeforces Round 662 赛后解题报告 梦幻开局到1400+的悲惨故事 A. Rainbow Dash, Fluttershy and Chess Coloring 这个题很简单,我们 ...
- Codeforces Educational Round 92 赛后解题报告(A-G)
Codeforces Educational Round 92 赛后解题报告 惨 huayucaiji 惨 A. LCM Problem 赛前:A题嘛,总归简单的咯 赛后:A题这种**题居然想了20m ...
随机推荐
- LeetCode-1034 边界着色
题目来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/coloring-a-border/ 题目描述 给你一个大小为 m x n 的整数矩阵 gri ...
- Xilinx URAM使用说明 UG573
UltraRAM Resources UltraRAM Summary UltraRAM 是单时钟.双端口.同步存储器,可用于 UltraScale+ 器件.由于 UltraRAM 与柱状(colum ...
- RESTful风格与Spring注解
RESTfulL是一种网络应用程序的设计风格和开发方式,即接口请求方式和路径的一种风格. 普通风格: localhost:8080/add?a=1&b=2 RestFul风格: localho ...
- 硬件监控:grafana+prometheus+node_exporter
一.前期准备: grafana:前端展示平台,没有数据存储功能,但是,它有不同的展示模板,然后,把后端数据库中提供的数据,进行展示 -->展示数据 prometheus(普罗米修斯):时序数据库 ...
- echarts来显示世界地图和全国地图,并且可以下钻层级
echarts来显示世界地图和全国地图,并且可以下钻层级 使用echarts来显示世界地图和全国地图,并且可以下钻层级 使用的技术 现有的功能 遇到的问题解决 总结 参考内容 直接来源码,地球资源包我 ...
- Mysql数据库基础第五章:(二)视图
Mysql数据库基础系列 软件下载地址 提取码:7v7u 数据下载地址 提取码:e6p9 mysql数据库基础第一章:(一)数据库基本概念 mysql数据库基础第一章:(二)mysql环境搭建 mys ...
- 启动项目报错org.yaml.snakeyaml.scanner.ScannerException: while scanning for the next token found character ‘@‘
报错信息:org.yaml.snakeyaml.scanner.ScannerException: while scanning for the next token found character ...
- js实现大转盘抽奖(vue举例)
在开发项目得时候遇到这样一个需求,在移动端项目有个支付抽奖页面,大概效果图如下: 简单介绍一下需求,点击抽奖按钮转盘转动,转盘里边黄色块块是个整张背景图,里边的商品是从接口获取得,包括奖品名称和图片, ...
- QML笔记
文章钢要: 1.qml基础知识 2.qml语言技巧 一.QML basic types QML Language提供的基础类型:int ,bool,string,double,real,var,url ...
- myJRebel 已不可用
周末在家里撸代码,突然 IDEA 提示 JRebel 需要激活. 原来一直使用的 myJRebel 的激活码,天真的以为是我的网络问题,尝试重新激活,结果不管用,就想去 myJrebel 的网站上去看 ...