题目

如果数组是单调递增或单调递减的,那么它是单调的。

如果对于所有 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;
}
};

最新文章

  1. CentOS 6.5安装Node.js, npm
  2. 让Git忽略所有obj和bin目录的同步
  3. 用window.print()打印指定div里面的内容(转载的)
  4. web应用中对配置文件的包装
  5. VS2012文本编辑器鼠标不能滚动
  6. hdu4185解题报告
  7. jQuery Moblile Demos学习记录Panel
  8. QT 线程池 + TCP 小试(一)线程池的简单实现
  9. Risk(最短路)
  10. iOS基础 - 单元测试
  11. 小白关于python 对象和内存的关系的一些感悟和疑惑,望大神指教
  12. Reactor-反应器模式
  13. Linux/Unix环境下的make命令详解
  14. odoo后台实现微信公众号验证
  15. day 15 - 1 内置函数
  16. OO的奇妙冒险——OOP入门与字符串处理
  17. Pattern Design - Strategy Pattern
  18. Android之 看“马达”如何贯通Android系统 (从硬件设计 --&gt; 驱动 --&gt; HAL --&gt; JNI --&gt; Framework --&gt; Application)
  19. 收藏清单: python测试数据生成及代码扫描最全工具列表
  20. 解决Maven管理项目update Maven时,jre自动变为1.5

热门文章

  1. zabbix api支持的数据类型
  2. VLAN(虚拟局域网)划分
  3. CSS+HTML+JQuery简单菜单
  4. Thread,Service和AsyncTask
  5. 1095 Cars on Campus (30)(30 分)
  6. ACM学习历程—HDU1392 Surround the Trees(计算几何)
  7. AIM Tech Round 4 (Div. 2)
  8. node.js Web应用框架Express入门指南
  9. 洛谷 2585 [ZJOI2006]三色二叉树——树形dp
  10. java对世界各个时区(TimeZone)的通用转换处理方法