每日一题Day21

每日一题Day21,第1张

每日一题Day21

1)题目

给你一个整数数组 nums ,判断这个数组中是否存在长度为 3 的递增子序列。如果存在这样的三元组下标 (i, j, k) 且满足 i < j < k ,使得 nums[i] < nums[j] < nums[k] ,返回 true ;否则,返回 false 。

示例 1:

输入:nums = [1,2,3,4,5]
输出:true
解释:任何 i < j < k 的三元组都满足题意
示例 2:

输入:nums = [5,4,3,2,1]
输出:false
解释:不存在满足题意的三元组
示例 3:

输入:nums = [2,1,5,0,4,6]
输出:true
解释:三元组 (3, 4, 5) 满足题意,因为 nums[3] == 0 < nums[4] == 4 < nums[5] == 6
提示:1 <= nums.length <= 5 * 105
            -231 <= nums[i] <= 231 - 1

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/increasing-triplet-subsequence

2)代码:

class Solution {
    public boolean increasingTriplet(int[] nums) {
       //数组元素数小于三,一定不存在
        if(nums.length<3)
        return false;
        //获取数组最大值
        int max=nums[0];
        for(int b:nums){
            if(b>=max)
            max=b;
        }
        //用最大值赋值,保证min1与min2不会为同一值(可能恰均为最小值)
        int min1=max;
        int min2=max;
        //保证min1为第一小,min2为第二小
        for(var a:nums){
            if(a<=min1){
            min1=a;
            }else if(a<=min2){
                min2=a;
            }else{
                return true;
            }
           
        }
     return false;
    }
}

3)

 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5702690.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存