欢迎来到起遇信息学
起遇信息学正处于上线筹建阶段,以下功能已全部开放免费体验: ✅ 完整题库浏览与代码提交评测(C / C++ / Python / Java 等) ✅ 入门到进阶的系列课程试读、作业与考试 ✅ AI 提示、AI 作业分析等智能助教功能 ✅ 赛事模拟与个人能力报告 ✅ 邮箱注册开放 ⏳ 付费课程订阅与微信/支付宝支付通道 ⏳ 手机号登录,微信扫码登录、微信公众号绑定 使用中如遇任何问题,欢迎通过页面底部 **"联系我们"** 与我们沟通。
CF831A.Unimodal Array
Unimodal Array
题目描述
一个整数数组是单峰的,如果:
一开始它是严格增加的;
之后是恒定不变的;
再后是严格减少的;
第一块(增加)和最后一块(减少)可能不存在。允许这两块都不存在。
例如,下面这三个数组是单峰的:
但是,下面这三个不是单峰的:
写一个程序来判断一个数组是否是单峰的。
输入格式
第一行包含一个整数 ( ) — 这个数组中元素的个数。
第二行包含 个整数 ( ) — 数组中的元素。
输出格式
如果,被给出的这个元素是单峰的,输出"YES",否则输出"NO"。
在任何情况,你都能输出每个字母(上面的或下面的)。
说明/提示
第一个样例中的数组是单峰的,因为它是在开始的时候严格递增(从位置 到位置 ,含端点),中间恒定不变(从位置 到位置 ,含端点)并在最后严格递减(从位置 到位置 ,含端点)。
by @Khassar
样例
6
1 5 5 5 4 2
YES
5
10 20 30 20 10
YES
4
1 2 1 2
NO
7
3 3 3 3 3 3 3
YES
在线编程 IDE
建议全屏模式获得最佳体验
键盘快捷键
| 进入全屏编程 | Alt+E |
| 递交评测 | Ctrl+Enter |
| 注释/取消注释 | Ctrl+/ |
| 缩放字体 | Ctrl+滚轮 |
第 1 行,第 1 列
0 字符
-
最近自测结果
暂未运行
最近递交结果
暂无递交记录