Skip to content

Commit

Permalink
Optimize longest_non_repeat.py (keon#914)
Browse files Browse the repository at this point in the history
Added window sliding approach to find longest non repeating sub string
  • Loading branch information
PIYUSH-GOSWAMI authored Feb 5, 2024
1 parent a336ee8 commit 1117ffe
Showing 1 changed file with 19 additions and 1 deletion.
20 changes: 19 additions & 1 deletion algorithms/arrays/longest_non_repeat.py
Original file line number Diff line number Diff line change
Expand Up @@ -88,4 +88,22 @@ def get_longest_non_repeat_v2(string):
max_len = index - start + 1
sub_string = string[start: index + 1]
used_char[char] = index
return max_len, sub_string
return max_len, sub_string

def get_longest_non_repeat_v3(string):
"""
Find the length of the longest substring
without repeating characters.
Uses window sliding approach.
Return max_len and the substring as a tuple
"""
longest_substring = ''
seen = set()
start_idx = 0
for i in range(len(string)):
while string[i] in seen:
seen.remove(string[start_idx])
start_idx += 1
seen.add(string[i])
longest_substring = max(longest_substring, string[start_idx: i+1], key=len)
return len(longest_substring), longest_substring

0 comments on commit 1117ffe

Please sign in to comment.