Increasing Triplet Subsequence
data:image/s3,"s3://crabby-images/08d73/08d735d2f09749a6244e27b7a5720e36e95716b3" alt="Jay Chouksey"
Introduction
Today, I tackled an interesting medium-level problem from LeetCode: Increasing Triplet Subsequence. This problem requires a good understanding of arrays and greedy algorithms. The goal is to determine if there exists a triplet in the array that follows the condition i<j<ki < j < ki<j<k and nums[i]<nums[j]<nums[k]nums[i] < nums[j] < nums[k]nums[i]<nums[j]<nums[k]. Let's dive into the problem statement, approach, and solution.
Problem Statement
Given an integer array nums
, return true
if there exists a triple of indices (i, j, k)
such that i < j < k
and nums[i] < nums[j] < nums[k]
. If no such indices exist, return false
.
Example 1:
Input: nums = [1,2,3,4,5]
Output: true
Explanation: Any triplet where i<j<ki < j < ki<j<k is valid.
Example 2:
Input: nums = [5,4,3,2,1]
Output: false
Explanation: No triplet exists.
Example 3:
Input: nums = [2,1,5,0,4,6]
Output: true
Explanation: The triplet (3, 4, 5) is valid because nums[3] == 0 < nums[4] == 4 < nums[5] == 6
.
Constraints:
1 <= nums.length <= 5 * 10<sup>5</sup>
-2<sup>31</sup> <= nums[i] <= 2<sup>31</sup> - 1
Approach to Solve the Problem
To solve this problem, we can use a greedy approach. Here’s the step-by-step approach:
Initialize Variables: Start with two variables,
first
andsecond
, and set them to the maximum possible integer value.Traverse the Array: Iterate through the array while updating
first
andsecond
based on the current element.Update Conditions:
If the current element is smaller than or equal to
first
, updatefirst
.Otherwise, if the current element is smaller than or equal to
second
, updatesecond
.If the current element is greater than both
first
andsecond
, returntrue
as it satisfies the triplet condition.
Return Result: If no triplet is found, return
false
.
Solution
Here’s the Java code that implements the above approach:
public static boolean find(int[] nums) {
int first = Integer.MAX_VALUE;
int second = Integer.MAX_VALUE;
for(int i = 0; i < nums.length; i++){
if(nums[i] <= first){
first = nums[i];
} else if (nums[i] <= second) {
second = nums[i];
} else{
return true;
}
}
return false;
}
Explanation
Initialization:
first
andsecond
are initialized toInteger.MAX_VALUE
to ensure that any number in the array will be smaller initially.Traverse the Array: As we iterate through the array, we update
first
andsecond
based on the current element's value.Update Conditions: The if-else conditions ensure that
first
holds the smallest value encountered so far,second
holds the next smallest value that is larger thanfirst
, and if we find an element larger than both, we have found our triplet.
Performance
This solution efficiently checks for the triplet in a single pass through the array, giving it a time complexity of O(n). The space complexity is O(1) as no additional space proportional to the input size is used.
Conclusion
This problem is a great example of how greedy algorithms can be used to solve array-related problems efficiently. By maintaining two variables to track the smallest and the second smallest values, we can determine the existence of the triplet in linear time.
I hope you found this explanation helpful. Stay tuned for more daily blogs on interesting problems and concepts I encounter in my learning journey!
Subscribe to my newsletter
Read articles from Jay Chouksey directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by
data:image/s3,"s3://crabby-images/08d73/08d735d2f09749a6244e27b7a5720e36e95716b3" alt="Jay Chouksey"
Jay Chouksey
Jay Chouksey
💡 Passionate about Core Java, currently diving deep into Data Structures & Algorithms and Advanced Java. Always eager to learn and share knowledge. 🚀