Codeforces 1291B - Array Sharpening
题目大意:
一个数列是尖锐的
当且仅当存在一个位置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的更多相关文章
- Codeforces Round #616 (Div. 2) B. Array Sharpening
t题目链接:http://codeforces.com/contest/1291/problem/B 思路: 用极端的情况去考虑问题,会变得很简单. 无论是单调递增,单调递减,或者中间高两边低的情况都 ...
- Codeforces 797E - Array Queries
E. Array Queries 题目链接:http://codeforces.com/problemset/problem/797/E time limit per test 2 seconds m ...
- Codeforces 1108E2 Array and Segments (Hard version) 差分, 暴力
Codeforces 1108E2 E2. Array and Segments (Hard version) Description: The only difference between eas ...
- CodeForces 300A Array
http://codeforces.com/problemset/problem/300/A 题意 :给你n个数字,让你分成3组,第一组各个数之积要小于0,第二组要大于0,第三组要等于0,符合要求的答 ...
- 网络流(最大流):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 ...
- Codeforces 1108E2 Array and Segments (Hard version)(差分+思维)
题目链接:Array and Segments (Hard version) 题意:给定一个长度为n的序列,m个区间,从m个区间内选择一些区间内的数都减一,使得整个序列的最大值减最小值最大. 题解:利 ...
- 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 ...
- CodeForces 57C Array 组合计数+逆元
题目链接: http://codeforces.com/problemset/problem/57/C 题意: 给你一个数n,表示有n个数的序列,每个数范围为[1,n],叫你求所有非降和非升序列的个数 ...
- codeforces A. Array 解题报告
题目链接:http://codeforces.com/problemset/problem/300/A 题目意思:给出n个数,将它们分成三批:1.所有数相乘的结果 < 0 2.所有数相乘的 ...
随机推荐
- P1065 单身狗
P1065 单身狗 转跳点:
- Java虚拟机05.2(内存分配)
jdk1.7中堆内存分为:年轻代+老年代+永久代.但是永久代有作为非堆内存存在,也就是说堆内存的大小应该为年轻代+老年代.在tomcat容器中,如果jsp页面过多可能出现永久代溢出.通常栈溢出都是程序 ...
- java虚拟机05(Java虚拟机的参数)
原文在此 (1)-Xms20M 表示设置堆容量的最小值为20M,必须以M为单位 (2)-Xmx20M 表示设置堆容量的最大值为20M,必须以M为单位.将-Xmx和-Xms设置为一样可以避免堆自动扩展. ...
- jenkins#安装gitlab
通过docker安装gitlab 参考 ------------------------------ 拉docker 镜像: docker pull gitlab/gitlab-ce 创建目录存储gi ...
- 【剑指Offer】面试题27. 二叉树的镜像
题目 请完成一个函数,输入一个二叉树,该函数输出它的镜像. 例如输入: 4 / \ 2 7 / \ / \ 1 3 6 9 镜像输出: 4 ...
- Linux学习总结《shell脚本》知识点关键-用好“过滤器”
- POJ 2752:Seek the Name, Seek the Fame
Seek the Name, Seek the Fame Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 13619 Accept ...
- CentOS 6.x 重置root 密码
1.重启,进入启动界面,快速按e,进入GNU GRUB界面. 2.选择第二项,按e,进行编辑. 3.在末尾输入1或single,回车,返回上一界面,还是选第二项,按b,进入单用户模式. 此时输入命令 ...
- C++编程学习(九)this指针&友元函数
mooc西工大魏英老师的课程通道关闭了,难受.现在边看工程代码边重温刷第一遍C++时候的知识点,顺序没有按照大纲的来,想到哪写到哪. this是干啥用的? 简介:在 C++ 中,每一个对象都能通过 t ...
- 微信公众号开发之根据OpenID列表群发(十四)
上一篇我们讲述了<微信公众号开发之根据标签进行群发(十二)>,这次我们讲解一下[根据OpenID列表群发] 根据OpenID列表群发[订阅号不可用,服务号认证后可用] 接口调用请求说明 h ...