334. 递增的三元子序列
给你一个整数数组 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 的三元组都满足题意
解析
我们使用两个指针标识前两个数,如果当前值小于one 则替换,小于two 替换,大于two我们就找到了。
class Solution {
public boolean increasingTriplet(int[] nums) {
int one = Integer.MAX_VALUE;
int two = Integer.MAX_VALUE;
for (int n : nums) {
if (n <= one) {
one = n;
} else if (n <= two) {
two = n;
} else {
return true;
}
}
return false;
}
}
注意:本文归作者所有,未经作者允许,不得转载