栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【Leetcode-每日一题】递增的三元子序列

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【Leetcode-每日一题】递增的三元子序列

递增的三元子序列
难度:中等

这里我的思路是存在递增的三元子序列的话,那么就存在
三元组 i < j < k,如果枚举中间位置 jj, 分别看 i < j 和 j

对于i < j,正向遍历数组,维护最小值,对于位置 i,表示[0,i]中的最小值。对于j < k,反向遍历数组,维护最大值,对于位置 i,表示[i,nums.length]中的最大值。
因此,遍历数组,考虑每一个位置 j,如果 nums[j]大于左边的 [0,i]中的最小值,小于右边的 [i,nums.length]中的最大值,即存在递增的三元子序列。
代码如下:

	public boolean increasingTriplet(int[] nums) {
        if (nums.length<3){
            return false;
        }
        int[] left = new int[nums.length];
        int[] right = new int[nums.length];
        left[0] = nums[0];
        for (int i = 1; i < nums.length; i++) {
            left[i] = nums[i] 0; i--) {
            right[i] = nums[i]>right[i+1] ? nums[i]:right[i+1];
        }

        for (int i = 0; i < nums.length; i++) {
            if (left[i] 

执行结果:成功

执行用时不理想,看看其他人的思路:
a 始终记录最小元素,b 为某个子序列里第二大的数。
接下来不断更新 a,同时保持 b 尽可能的小。
如果下一个元素比 b 大,说明找到了三元组。
代码如下:

	public boolean increasingTriplet1(int[] nums) {
        int a = Integer.MAX_VALUE; 
        int b = Integer.MAX_VALUE;
        for (int n: nums){
            if (n <= a) a = n;
            else if (n <= b) b = n;
            else return true;
        }
        return false;
    }

执行结果:成功

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/704813.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号