[LeetCode] Increasing Triplet Subsequence
LeetCode Subsequence Increasing
2023-09-11 14:14:42 时间
Given an unsorted array return whether an increasing subsequence of length 3 exists or not in the array.
Formally the function should:
Return true if there exists i, j, k
such that arr[i] < arr[j] < arr[k] given 0 ≤ i < j < k ≤ n-1 else return false.
Your algorithm should run in O(n) time complexity and O(1) space complexity.
Examples:
Given [1, 2, 3, 4, 5]
,
return true
.
Given [5, 4, 3, 2, 1]
,
return false
.
解题思路
初始化时设置n1、n2为0x7fffffff。遍历数组:
- 若n小于等于n1,则n1=n;
- 否则,若n小于等于n2,则n2=n;
- 否则,返回true;
该过程不断缩小n1、n2,最后查看是否具有比n1、n2都小的数。
实现代码
// Runtime: 1 ms
public class Solution {
public boolean increasingTriplet(int[] nums) {
int n1 = 0x7fffffff;
int n2 = 0x7fffffff;
for (int n : nums) {
if (n <= n1) {
n1 = n;
} else if (n <= n2) {
n2 = n;
} else {
return true;
}
}
return false;
}
}
相关文章
- Java实现 LeetCode 748 最短完整词(字母拆分+暴力)
- Java实现 LeetCode 410 分割数组的最大值
- 每日一道 LeetCode (29):杨辉三角 II
- [LeetCode] Increasing Triplet Subsequence
- LeetCode(34):搜索范围
- LeetCode-9. 回文数
- Python 刷Leetcode题库,顺带学英语单词(47)
- Leetcode 1331. 数组序号转换
- Leetcode 217 Contains Duplicate
- leetcode 232. Implement Queue using Stacks
- leetcode 594. Longest Harmonious Subsequence
- leetcode 697. Degree of an Array
- 【Leetcode刷题Python】 LeetCode 2038. 如果相邻两个颜色均相同则删除当前颜色
- 【LeetCode】查找和最小的K对数字