博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[LintCode] Longest Increasing Continuous Subsequence 最长连续递增子序列
阅读量:6839 次
发布时间:2019-06-26

本文共 1184 字,大约阅读时间需要 3 分钟。

 

Give an integer array,find the longest increasing continuous subsequence in this array.

An increasing continuous subsequence:

  • Can be from right to left or from left to right.
  • Indices of the integers in the subsequence should be continuous.
 Notice

O(n) time and O(1) extra space.

Example

For [5, 4, 2, 1, 3], the LICS is [5, 4, 2, 1], return 4.

For [5, 1, 2, 3, 4], the LICS is [1, 2, 3, 4], return 4.

 

这道题跟LeetCode上那道很像,但是比那道题简单,因为这道题需要递增子序列连续,这样我们只要挨个比较一下即可,由于题目中说了左右两个方向递增都行,可以用左右两个方向分别遍历一遍,也可以把两个遍历合并到一起,只用一个循环,同时寻找递增和递减的数列,使用两个变量cnt1和cnt2分别记录最长递增和递减数列的长度,一旦递增递减断开,记得将对应的计数器重置即可,参见代码如下:

 

class Solution {public:    /**     * @param A an array of Integer     * @return  an integer     */    int longestIncreasingContinuousSubsequence(vector
& A) { if (A.empty()) return 0; int res = 1, cnt1 = 1, cnt2 = 1; for (int i = 0; i < A.size() - 1; ++i) { if (A[i] < A[i + 1]) { ++cnt1; cnt2 = 1; } else { ++cnt2; cnt1 = 1; } res = max(res, max(cnt1, cnt2)); } return res; }};

 

类似题目:

转载地址:http://umqkl.baihongyu.com/

你可能感兴趣的文章
单例模式
查看>>
awk用法(三)
查看>>
谷歌深度学习公开课任务 5: Word2Vec&CBOW
查看>>
让Python不在mac的dock上显示火箭图标
查看>>
Oracle 数据库EM访问多个Instance
查看>>
理解 Delphi 的类(十) - 深入方法[28] - 递归函数实例: 搜索当前目录下的所有嵌套目录...
查看>>
前端纪实
查看>>
学 Win32 汇编[12]: PTR、OFFSET、ADDR、THIS
查看>>
WinAPI: GetLocalTime、SetLocalTime、SetSystemTime - 获取与设置系统时间
查看>>
关于 Delphi 中流的使用(6) 用流读写结构化文件
查看>>
复杂的结构化存取(一)
查看>>
web前端性能优化
查看>>
如何通过jq和php实现返回父级页面(附带记忆功能)
查看>>
Centos下运行gpg --gen-key生成key时出现卡住解决方案笔记
查看>>
Java时间操作工具类
查看>>
XML转JSON的javascript代码
查看>>
PHP冒泡排序详解
查看>>
Zabbi监控系统搭建
查看>>
创建github账号
查看>>
【hibernate系列】采用p6spy+SQLProfiler完整显示hibernate的S...
查看>>