334.递增的三元子序列

简介: 334.递增的三元子序列

题目:给你一个整数数组 nums ,判断这个数组中是否存在长度为 3 的递增子序列。

如果存在这样的三元组下标 (i, j, k) 且满足 i < j < k ,使得 nums[i] < nums[j] < nums[k] ,返回 true ;否则,返回 false 。

解题思路:

初始值的时候,已经满足second > first了,现在找第三个数third

(1) 如果third比second大,那就是找到了,直接返回true

(2) 如果third比second小,但是比first大,那就把second指向third,然后继续遍历找third

(3) 如果third比first还小,那就把first指向third,然后继续遍历找third(这样的话first会跑到second的后边,但是不要紧,因为在second的前边,老first还是满足的)

class Solution{
    public boolean increasingTriplet(int[] nums){
        int n=nums.length;
        if(n<3){
            return false;        
        }
        int first=nums[0],second=Integer.MAX_VALUE;
        for(int i=1;i<n;i++){
            int num=nums[i];
            if(num>second){
                return true;            
            }else if(num>first){
                second=num;            
            }else{
                first=num;            
            }        
        }  
        return false;  
    }
}


相关文章
|
8月前
|
设计模式 算法 Java
【数据结构和算法】递增的三元子序列
给你一个整数数组nums,判断这个数组中是否存在长度为3的递增子序列。 如果存在这样的三元组下标(i, j, k)且满足i < j < k,使得nums[i] < nums[j] < nums[k],返回true;否则,返回false。
80 3
|
8月前
三元上升子序列
三元上升子序列
35 0
|
算法 测试技术 C#
C++二分算法:使数组严格递增
C++二分算法:使数组严格递增
|
7月前
|
C++
给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
LeetCode-334 递增的三元子序列
LeetCode-334 递增的三元子序列
|
8月前
leetcode-334:递增的三元子序列
leetcode-334:递增的三元子序列
42 0
|
8月前
|
算法 测试技术 C#
前缀和+单调双队列+贪心:LeetCode2945:找到最大非递减数组的长度
前缀和+单调双队列+贪心:LeetCode2945:找到最大非递减数组的长度
|
8月前
|
人工智能 算法 BI
【前缀和】【分类讨论】【二分查找】2983:回文串重新排列查询
【前缀和】【分类讨论】【二分查找】2983:回文串重新排列查询
|
存储 算法
【LeetCode】每日一题&最后一个单词的长度&投票法求解多数元素&异或操作符巧解只出现一次的数字&整数反转
【LeetCode】每日一题&最后一个单词的长度&投票法求解多数元素&异或操作符巧解只出现一次的数字&整数反转
|
8月前
|
存储 编译器 C语言
Day2 排序子序列、倒置字符串
Day2 排序子序列、倒置字符串
60 0

热门文章

最新文章