解题报告: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 ...
随机推荐
- 自定义顺序表ArrayList
1.简介 顺序表是在计算机内存中以数组的形式保存的线性表,线性表的顺序存储是指用一组地址连续的存储单元依次存储线性表中的各个元素.使得线性表中在逻辑结构上相邻的数据元素存储在相邻的物理存储单元中,即通 ...
- LeetCode-1719 重构一棵树的方案数
来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/number-of-ways-to-reconstruct-a-tree 题目描述 给你一个数组 ...
- 线程join detach 僵尸线程
进程死亡后,由父进程负责回收PCB资源,不回收则会出现僵尸进程 对于线程来说,任何一个线程都可以回收另一个线程的资源 在子线程终止后,通常在主线程中通过pthread_join来回收子线程的资源,获取 ...
- ubuntu 启动脚本变化
ubuntu-16.10 开始不再使用initd管理系统,改用systemd- 快速看了 systemd 的使用方法,发现改动有点大, 包括用 systemctl 命令来替换了 service 和 c ...
- Kotlin学习-类(嵌套类,内部类,数据类,静态类)及类扩展
一般类形式: class Person(var name: String){//构造函数放在类头部 var age = 1 var fulName: String var address = &quo ...
- windows10 远程桌面黑屏
[计算机配置]-[管理模板]-[Windows组件]-[远程桌面服务]-[远程桌面会话主机]-[远程会话环境]-{为远程桌面连接使用WDDM图形显示驱动程序-设置禁用}
- s-hr实现单点登录,看我这份笔记就够了!!!
https://pan.kingdee.com/s/MTA5ODk4NyxjNzk1来自:云之家企业云盘
- http协议与tcp协议的理解
1.区别 tcp协议是对应于传输层,http协议是对应于应用层,从本质上来说,二者是没有可比性的.http协议是建立在tcp协议基础之上的,当浏览器需要从服务器获取网页数据的时候,会发送一次http请 ...
- windows下搭建h5游戏小小火影教程【附安装包】
小小三国是一款很好玩的H5游戏.只需要用一台64位的windows电脑或服务器,你就可以和朋友们一起联机玩这个游戏了.本文将会教你如何搭建这个游戏,步骤如下. 1.下载好后你会看到该压缩包 2.解压到 ...
- golang 切片(slice)
1.切片的定义 切片(slice)是对数组一个连续片段的引用,所以切片是一个引用类型. 切片的使用与数组类似,遍历,访问切片元素等都一样.切片是长度是可以变化的,因此切片可以看做是一个动态数组. 一个 ...