题目大意:

一个数列是尖锐的

当且仅当存在一个位置k使得 a[1]<a[2]<a[3]<...<a[k] 且 a[k]>a[k+1]>a[k+2]>...>a[n]

现在你可以任意让某些严格为正整数的元素执行操作使它们的值 -1

问能不能通过这么一系列操作去锐化这个数组(也可以不操作)

注意,严格递增或者严格递减的数组也是尖锐的(k可以为1或者n)

解题思路:

要锐化一个数组

只需要让他能够满足完全递增、完全递减、先递增后递减即可

因为任意元素都能执行任意次-1

所以不妨直接化成最直观的答案

即最后化成类似 0 1 2 3 ... 3 2 1 0 的样式

如果数组元素个数为奇数,如上可满足

但是如果为偶数,中间两位不能相同

根据上方的最简样式,可以得到,从前往后一直到k位置,数组是递增的

从后往前看到第k个位置,数组还是递增的

所以不妨去循环判断每一个元素是否满足条件

即从前往后,i=0~n-1,判断每一位是否满足ar[i]>=i

如果不满足,说明从前往后的递增断在了这个位置

用变量pl记录这个位置

从后往前,i=n-1~0,判断每一位是否满足ar[i]>=n-i+1

如果不满足,说明从后往前递增断在了这个位置

用变量pr记录这个位置

(注意完全递增递减的情况下对pl和pr的特殊处理)

最后,判断pl>=pr是否成立,成立则说明数组可以锐化,否则,pl到pr之间这一段无法进行锐化

#include<bits/stdc++.h>
using namespace std;
int ar[];
void solve(){
int N,i,tmp,pl,pr;
bool flag=true;
cin>>N;
if(N==)
cin>>ar[];
else if(N==){
cin>>ar[]>>ar[];
if(ar[]+ar[]==)
flag=false;
}
else if(N>=){
for(i=;i<N;i++)
cin>>ar[i];
for(i=;i<N;i++)
if(ar[i]<i){
pl=i-;
break;
}
if(i==N)
pl=N-;
for(i=N-;i>=;i--)
if(ar[i]<N-i-){
pr=i+;
break;
}
if(i==-)
pr=;
if(pl<pr)
flag=false;
}
cout<<(flag?"Yes\n":"No\n");
}
int main(){
ios::sync_with_stdio();
cin.tie();cout.tie();
int T;cin>>T;while(T--)
solve(); return ;
}

Codeforces 1291B - Array Sharpening的更多相关文章

  1. Codeforces Round #616 (Div. 2) B. Array Sharpening

    t题目链接:http://codeforces.com/contest/1291/problem/B 思路: 用极端的情况去考虑问题,会变得很简单. 无论是单调递增,单调递减,或者中间高两边低的情况都 ...

  2. Codeforces 797E - Array Queries

    E. Array Queries 题目链接:http://codeforces.com/problemset/problem/797/E time limit per test 2 seconds m ...

  3. Codeforces 1108E2 Array and Segments (Hard version) 差分, 暴力

    Codeforces 1108E2 E2. Array and Segments (Hard version) Description: The only difference between eas ...

  4. CodeForces 300A Array

    http://codeforces.com/problemset/problem/300/A 题意 :给你n个数字,让你分成3组,第一组各个数之积要小于0,第二组要大于0,第三组要等于0,符合要求的答 ...

  5. 网络流(最大流):CodeForces 499E Array and Operations

    You have written on a piece of paper an array of n positive integers a[1], a[2], ..., a[n] and m goo ...

  6. Codeforces 1108E2 Array and Segments (Hard version)(差分+思维)

    题目链接:Array and Segments (Hard version) 题意:给定一个长度为n的序列,m个区间,从m个区间内选择一些区间内的数都减一,使得整个序列的最大值减最小值最大. 题解:利 ...

  7. Codeforces 623B Array GCD

    Array GCD 最后的序列里肯定有a[1], a[1]-1, a[1]+1, a[n], a[n]-1, a[n]+1中的一个,枚举质因子, dp去check #include<bits/s ...

  8. CodeForces 57C Array 组合计数+逆元

    题目链接: http://codeforces.com/problemset/problem/57/C 题意: 给你一个数n,表示有n个数的序列,每个数范围为[1,n],叫你求所有非降和非升序列的个数 ...

  9. codeforces A. Array 解题报告

    题目链接:http://codeforces.com/problemset/problem/300/A 题目意思:给出n个数,将它们分成三批:1.所有数相乘的结果 < 0    2.所有数相乘的 ...

随机推荐

  1. CentOS 7 搭建本地YUM仓库,并定期同步阿里云源

    目录导航: 1. 系统环境 2. 修改yum 源为阿里云源 3. 安装yum相关的软件 4. 根据源标识同步源到本地目录 5. 安装nginx开启目录权限保证本地机器可以直接本地yum源 6. 客户端 ...

  2. ThinkPhp3.2.3缓存漏洞复现以及修复建议

    小编作为一个php(拍黄片)的程序员,今天早上无意间看到thinkphp的缓存漏洞,小编在实际开发过程中用thinkphp3.2.3挺多的. 我们这里来复现一下漏洞 后面我会提出修复建议 首先我们下载 ...

  3. 图形与动画在Android中的实现

    public class MyView extends View{ Bitmap myBitmap; Paint paint; public MyView(Context context, Attri ...

  4. 059、Java中定义一个有参数无返回值的方法

    01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...

  5. Jetbrains推出了一款新的编程字体Mono

    今天看到新闻说Jetbrains推出了一款新的编程字体Mono,便到官网上下载试了一下, 在VS和VS Code中显示效果都非常不错,是并且支持连体,感兴趣的朋友可以到其官网下载试用一下.

  6. 载域和运行域的理解(ARM程序是怎么运行的)

    对ARM加载域和运行域的理解 一般而言,一个程序包括只读的代码段和可读写的数据段.在ARM的集成开发环境中,只读的代码段和常量被称作RO段(ReadOnly):可读写的全局变量和静态变量被称作RW段( ...

  7. mybatis-plus 乐观锁

    参见:https://mp.baomidou.com/guide/optimistic-locker-plugin.html#%E4%B8%BB%E8%A6%81%E9%80%82%E7%94%A8% ...

  8. windows下修改pip安装源的办法

    之前的随笔里有写过关于Mac OS和Linux的,现在需要用到Windows的系统, 修改方法:路径----> C:\Users\用户名\AppData\Roaming,在Roaming文件夹下 ...

  9. P1010 一元多项式求导

    1010 一元多项式求导 (转跳点:

  10. [YOLO]《You Only Look Once: Unified, Real-Time Object Detection》笔记

    一.简单介绍 目标检测(Objection Detection)算是计算机视觉任务中比较常见的一个任务,该任务主要是对图像中特定的目标进行定位,通常是由一个矩形框来框出目标. 在深度学习CNN之前,传 ...