-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy path0300-longest-increasing-subsequence.rs
40 lines (33 loc) · 1.66 KB
/
0300-longest-increasing-subsequence.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/*
Problem: LeetCode 300 - Longest Increasing Subsequence
Key Idea:
The key idea is to use dynamic programming to find the length of the longest increasing subsequence in the given array.
Approach:
1. Initialize a vector `dp` of the same length as the input vector `nums`, all initially set to 1.
- `dp[i]` will represent the length of the longest increasing subsequence ending at index `i`.
- Initialize it to 1 because a single element is always a valid subsequence.
2. Iterate through the input vector `nums` from the second element to the end.
3. For each element `nums[i]`, iterate through the elements from the start to index `i - 1`:
- For each element `nums[j]`, if `nums[i]` is greater than `nums[j]`, update `dp[i]` to the maximum of `dp[i]` and `dp[j] + 1`.
- This means that if we can extend an increasing subsequence ending at index `j` with `nums[i]`, we update the length of the increasing subsequence ending at index `i`.
4. After the iteration, the maximum value in the `dp` vector will be the length of the longest increasing subsequence.
5. Return this maximum value as the result.
Time Complexity:
O(n^2), where `n` is the length of the input vector `nums`. We have nested loops for each element.
Space Complexity:
O(n), as we use a vector of size `n` to store the dynamic programming values.
*/
impl Solution {
pub fn length_of_lis(nums: Vec<i32>) -> i32 {
let n = nums.len();
let mut dp = vec![1; n];
for i in 1..n {
for j in 0..i {
if nums[i] > nums[j] {
dp[i] = dp[i].max(dp[j] + 1);
}
}
}
dp.iter().cloned().max().unwrap_or(0)
}
}