-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathword-break.py3
More file actions
61 lines (49 loc) · 1.92 KB
/
word-break.py3
File metadata and controls
61 lines (49 loc) · 1.92 KB
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
# 139. Word Break (8/31/57428)
# Runtime: 3 ms (65.96%) Memory: 18.12 MB (7.00%)
# Time Complexity without cache O(2^n), where n = LENGTH OF STRING s
# Time Complexity with cache O(n^2)
# Space Complexity O(m)
# - At position i, we try all possible endings j (from i to n-1)
# - For each valid word found, we make a recursive call
# - In worst case: every substring is a valid word -> eg s=abc wordList=[a,b,c]
#
# T(n) = T(n-1) + T(n-2) + T(n-3) + ... + T(1) + T(0)
# This gives us T(n) = O(2^n)
# Example:
# s = "aaaaaaa", wordDict = ["aaaa", "aaa"]
#
# findWords(0)
# "aaaaaaa"
# |
# +--------+--------+
# | |
# findWords(3) findWords(4)
# "aaaa" (aaa) "aaa" (aaaa)
# | |
# +--------+--------+ |
# | | |
# findWords(6) findWords(7) findWords(7)
# "a" (aaa) i==len(s) i==len(s)
# | | |
# X V V
# s = # "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaab"
# wordDict = ["a","aa","aaa","aaaa","aaaaa","aaaaaa","aaaaaaa","aaaaaaaa","aaaaaaaaa","aaaaaaaaaa"]
# cache needed in the above case
class Solution:
def wordBreak(self, s: str, wordDict: List[str]) -> bool:
wordSet = set(wordDict)
# dictionry for cache
cache = {}
def dfs(i):
if i == len(s):
return True
if i in cache:
return cache[i]
for j in range(i, len(s)):
if s[i : j + 1] in wordSet:
if dfs(j + 1):
cache[i] = True
return True
cache[i] = False
return False
return dfs(0)