Leetcode:单调数列
2024-08-24 02:32:49
题目
如果数组是单调递增或单调递减的,那么它是单调的。
如果对于所有 i <= j,A[i] <= A[j],那么数组 A 是单调递增的。 如果对于所有 i <= j,A[i]> = A[j],那么数组 A 是单调递减的。
当给定的数组 A 是单调数组时返回 true,否则返回 false。
测试案例:
示例 1:
输入:[1,2,2,3]
输出:true
示例 2:
输入:[6,5,4,4]
输出:true
示例 3:
输入:[1,3,2]
输出:false
示例 4:
输入:[1,2,4,5]
输出:true
示例 5:
输入:[1,1,1]
输出:true
解法
这道题开始做的时候开始想当然了,以为是单调增;思考过后只需要加上判断条件就可以了:
class Solution {
public:
// bool isMonotonic(vector<int>& A) {
// vector<int>::iterator iter;
// int temp = A[0];
// for (iter = A.begin(); iter != A.end(); ++iter)
// {
// if (*iter == temp)
// continue;
// if (*iter < temp)
// return false;
// temp = *iter;
// }
// return true;
// }
bool isMonotonic(vector<int>& A) {
if (A.size() == 1)
return true;
bool judge=1;
for (int i = 1; i < A.size(); i++)
{
if (i == A.size()-1)
return true;
if (A[i] == A[i - 1])
continue;
judge = (A[i] - A[i - 1]) > 0 ? 1 : 0;
break;
}
for (int j = 1; j < A.size(); j++)
{
if (judge == 1 && A[j] - A[j - 1] < 0)
return false;
if (judge == 0 && A[j] - A[j - 1] > 0)
return false;
}
return true;
}
};
最新文章
- CentOS 6.5安装Node.js, npm
- 让Git忽略所有obj和bin目录的同步
- 用window.print()打印指定div里面的内容(转载的)
- web应用中对配置文件的包装
- VS2012文本编辑器鼠标不能滚动
- hdu4185解题报告
- jQuery Moblile Demos学习记录Panel
- QT 线程池 + TCP 小试(一)线程池的简单实现
- Risk(最短路)
- iOS基础 - 单元测试
- 小白关于python 对象和内存的关系的一些感悟和疑惑,望大神指教
- Reactor-反应器模式
- Linux/Unix环境下的make命令详解
- odoo后台实现微信公众号验证
- day 15 - 1 内置函数
- OO的奇妙冒险——OOP入门与字符串处理
- Pattern Design - Strategy Pattern
- Android之 看“马达”如何贯通Android系统 (从硬件设计 -->; 驱动 -->; HAL -->; JNI -->; Framework -->; Application)
- 收藏清单: python测试数据生成及代码扫描最全工具列表
- 解决Maven管理项目update Maven时,jre自动变为1.5
热门文章
- zabbix api支持的数据类型
- VLAN(虚拟局域网)划分
- CSS+HTML+JQuery简单菜单
- Thread,Service和AsyncTask
- 1095 Cars on Campus (30)(30 分)
- ACM学习历程—HDU1392 Surround the Trees(计算几何)
- AIM Tech Round 4 (Div. 2)
- node.js Web应用框架Express入门指南
- 洛谷 2585 [ZJOI2006]三色二叉树——树形dp
- java对世界各个时区(TimeZone)的通用转换处理方法