456. 132模式
难度中等382收藏分享切换为英文接收动态反馈
给你一个整数数组 nums
,数组中共有 n
个整数。132 模式的子序列 由三个整数 nums[i]
、nums[j]
和 nums[k]
组成,并同时满足:i < j < k
和 nums[i] < nums[k] < nums[j]
。
如果 nums
中存在 132 模式的子序列 ,返回 true
;否则,返回 false
。
进阶:很容易想到时间复杂度为 O(n^2)
的解决方案,你可以设计一个时间复杂度为 O(n logn)
或 O(n)
的解决方案吗?
示例 1:
1 | 输入:nums = [1,2,3,4] |
示例 2:
1 | 输入:nums = [3,1,4,2] |
示例 3:
1 | 输入:nums = [-1,3,2,0] |
提示:
n == nums.length
1 <= n <= 10^4
-109 <= nums[i] <= 10^9
单调栈维护最大的元素
1 | class Solution { |
使用TreeMap
1 | class Solution { |