-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Copy pathlength_longest_common_substring.jl
56 lines (44 loc) · 1.55 KB
/
length_longest_common_substring.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
"""Length of Longest Common Substring problem in Julia
Given two strings, we have to find the longest common substring in Julia
The problem can be solved using Dynamic Programming
"""
function lengthoflongestcommonsubstring(S1, S2)
# Build a 2D matrix in Bottom-Up manner. Every element
# dp[i][j] contains the length of the longest common substring
# of S1[0 .. i] and S2[0 .. j].
n = length(S1)
m = length(S2)
ans = 0
# Fill every element of the 2D matrix with 0 as value
dp = zeros(Int, n+1, m+1)
for i in 1:(n+1)
for j in 1:(m+1)
# length of LCS when one of the string is empty is zero
if i == 1 || j == 1
dp[i,j] = 0
# If the elements of both the strings match, then
# the value of LCS increments by one.
# Also Check if the value of lcs has reached the max till now.
elseif S1[i-1] == S2[j-1]
dp[i,j] = dp[(i - 1),(j - 1)] + 1
ans = max(ans, dp[i,j])
else
dp[i,j] = 0
end
end
end
return ans
end
print("Enter the first string: ")
s1 = readline()
print("Enter the second string: ")
s2 = readline()
res = lengthoflongestcommonsubstring(s1, s2)
print("The length of the longest common substring is ")
print(res)
# Time Complexity: O(n * m), where n, m are the size of the given strings
# Space Complexity: O(n * m)
# SAMPLE INPUT AND OUTPUT
# Enter the first string: runner
# Enter the second string: run
# The length of the longest common substring is 3