-
Notifications
You must be signed in to change notification settings - Fork 1.1k
/
length_longest_decreasing_subsequence.jl
63 lines (49 loc) · 1.85 KB
/
length_longest_decreasing_subsequence.jl
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
""" Julia program to find the Length of Longest Decreasing Subsequence
In this problem, given an array we have to find the length of the longest decreasing subsequence that array can make.
The problem can be solved using Dynamic Programming.
"""
function length_longest_decreasing_subsequence(arr, n)
max_len = 0
# Initialize the dp array with the 1 as value, as the maximum length
# at each point is atleast 1, by including that value in the sequence
dp = ones(Int, n)
""" Now Lets Fill the dp array in Bottom-Up manner
Compare Each i'th element to its previous elements from 0 to i-1,
If arr[i] < arr[j](where j = 0 to i-1), then it qualifies for decreasing subsequence and
If dp[i] < dp[j] + 1, then that subsequence qualifies for being the longest one"""
for i in 1:n
for j in 1:(i-1)
if(arr[i] < arr[j] && dp[i] < dp[j] + 1)
dp[i] = dp[j] + 1
end
end
end
# Now Find the largest element in the dp array
max_len = findmax(dp)[1]
return max_len
end
print("What is the length of the array? ")
n = readline()
n = parse(Int, n)
if (n <= 0)
println("No numbers present in the array!!!")
exit()
end
arr = Int[]
print("Enter the numbers: ")
arr = [parse(Int, num) for num in split(readline())]
res = length_longest_decreasing_subsequence(arr, n)
print("The length of the longest decreasing subsequence of the given array is $res")
"""
Time Complexity - O(n^2), where 'n' is the size of the array
Space Complexity - O(n)
SAMPLE INPUT AND OUTPUT
SAMPLE I
What is the length of the array? 5
Enter the numbers: 5 4 3 2 1
The length of the longest decreasing subsequence of the given array is 5
SAMPLE II
What is the length of the array? 10
Enter the numbers: 15 248 31 66 84 644 54 84 5 88
The length of the longest decreasing subsequence of the given array is 4
"""