贪心算法day3(最长递增序列问题)

目录

1.最长递增三元子序列

2.最长连续递增序列


1.最长递增三元子序列

题目链接:. - 力扣(LeetCode)

思路:我们只需要设置两个数进行比较就好。设a为nums[0],b 为一个无穷大的数,只要有比a小的数字就赋值a,比a大的数字就赋值b,如果有比b大的数字说明可以组成一个三元子序列直接返回true

代码如下:

复制代码
class Solution {
    public static   boolean increasingTriplet(int[] nums) {
        int a = nums[0],b = Integer.MAX_VALUE;
        for (int i = 0; i < nums.length; i++) {
            if(nums[i] > b){
                return true;
            } else if (nums[i] < a) {
                a = nums[i];
            }else if(nums[i] > a){ 
                b = nums[i];
            }
        }
        return false;
    }
}

2.最长连续递增序列

题目链接:. - 力扣(LeetCode)

思路:双指针遍历

代码:

复制代码
class Solution {
        public int findLengthOfLCIS(int[] nums) {
           int n = nums.length,ret = 0;
        for (int i = 0; i < n; ) {
            int j = i +1;
            while(j < n && nums[j] >nums[j -1])j++;
            ret = Math.max(ret,j-i);
            i = j;
        }
        return ret;
    }
}
相关推荐
断剑zou天涯43 分钟前
【算法笔记】窗口内最大值或最小值的更新结构
java·笔记·算法
smj2302_796826521 小时前
解决leetcode第3753题范围内总波动值II
python·算法·leetcode
骑着猪去兜风.3 小时前
线段树(二)
数据结构·算法
fengfuyao9854 小时前
竞争性自适应重加权算法(CARS)的MATLAB实现
算法
散峰而望4 小时前
C++数组(二)(算法竞赛)
开发语言·c++·算法·github
leoufung4 小时前
LeetCode 92 反转链表 II 全流程详解
算法·leetcode·链表
wyhwust5 小时前
交换排序法&冒泡排序法& 选择排序法&插入排序的算法步骤
数据结构·算法·排序算法
利刃大大5 小时前
【动态规划:背包问题】完全平方数
c++·算法·动态规划·背包问题·完全背包
wyhwust5 小时前
数组----插入一个数到有序数列中
java·数据结构·算法
im_AMBER5 小时前
Leetcode 59 二分搜索
数据结构·笔记·学习·算法·leetcode