T456、132模式

作者: 上行彩虹人 | 来源:发表于2020-06-26 19:22 被阅读0次

给定一个整数序列:a1, a2, ..., an,一个132模式的子序列 ai, aj, ak 被定义为:当 i < j < k 时,ai < ak < aj。设计一个算法,当给定有 n 个数字的序列时,验证这个序列中是否含有132模式的子序列。
注意:n 的值小于15000。
示例1:
输入: [1, 2, 3, 4]
输出: False
解释: 序列中不存在132模式的子序列。
示例 2:
输入: [3, 1, 4, 2]
输出: True

解释: 序列中有 1 个132模式的子序列: [1, 4, 2].
示例 3:
输入: [-1, 3, 2, 0]
输出: True
解释: 序列中有 3 个132模式的的子序列: [-1, 3, 2], [-1, 3, 0] 和 [-1, 2, 0].

问题可以转化为求当前数小于后面的次最大数,从后往前遍历数组,使用一个栈记录遍历结果,如果第i个数大于栈顶元素,那么次最大数就为栈顶元素,i入栈。

   public boolean find132pattern(int[] nums) {
        if(nums.length < 3)
            return false;
        int len = nums.length, second_max = Integer.MIN_VALUE;
        Stack<Integer> s = new Stack<>();
        for(int i = len-1; i >= 0; i--){
            if(nums[i] < second_max)
                return true;
            while(!s.isEmpty() && s.peek() < nums[i]){
                second_max = s.pop();
            }
            s.push(nums[i]);
        }       
        return false;
  }

相关文章

  • T456、132模式

    给定一个整数序列:a1, a2, ..., an,一个132模式的子序列 ai, aj, ak 被定义为:当 i ...

  • LeetCode 456: 132模式

    LeetCode 456题 132模式 题目 给定一个整数序列:a1, a2, ..., an,一个132模式的子...

  • 栈-N456-132模式

    题目 概述:给定一个整数数组,判断该数组里是否有满足132模式的序列(132模式:序列中的第一个数 < 序列中的第...

  • 132模式(单调栈)

    这道题用了单调栈,从后往前,这样就能保证栈顶的序号一定最大,为k, 单调栈维护一个递减序列,所以从后往前遍历数组,...

  • [刷题防痴呆] 0456 - 132模式 (132 Patter

    题目地址 https://leetcode.com/problems/132-pattern[https://le...

  • 有感于上海学习(之一)

    由“模式能企业管理咨询(上海)有限公司”举办的为期4天3夜的第132期 ――《商业模式转换―快速盈利》学习交流会已...

  • 2/7—1组O9—anj

    知识变现 (摘第132页) 知识变现的模式:知识变现每个人都有,不一样的是每个人的变现模式是不同的。 ...

  • IOS 算法(中级篇) ----- 132模式

    给你一个整数数组 nums ,数组中共有 n 个整数。132 模式的子序列 由三个整数 nums[i]、nums[...

  • 力扣-[中等]

    给你一个整数数组 nums ,数组中共有 n 个整数。132 模式的子序列 由三个整数 nums[i]、nums[...

  • 52832 PA

    PA / LNA support in S132 The S132 SoftDevice for the nRF5...

网友评论

    本文标题:T456、132模式

    本文链接:https://www.haomeiwen.com/subject/kdiufktx.html