LeetCode题解(0291):单词规律II(Python)

王小沫

关注

阅读 56

2022-02-24


题目:​​原题链接​​(困难)

标签:回溯算法

解法

时间复杂度

空间复杂度

执行用时

Ans 1 (Python)

O ( N × P ) : 其中P为pattern中的不同字母数

O ( N + P )

236ms (49.12%)

Ans 2 (Python)

Ans 3 (Python)

解法一:

class Solution:
def __init__(self):
self.dic1 = {} # 从pattern到s的映射
self.dic2 = {} # 从s到pattern的映射

def wordPatternMatch(self, pattern: str, s: str, i1=0, i2=0) -> bool:
if i1 == len(pattern) and i2 == len(s):
return True
elif i1 == len(pattern):
return False
elif pattern[i1] in self.dic1:
ch = self.dic1[pattern[i1]]
size = len(ch)
if len(s) - i2 >= size and ch == s[i2:i2 + size]:
return self.wordPatternMatch(pattern, s, i1 + 1, i2 + size)
else:
return False
else:
for i in range(1, len(s) - i2 + 1):
p = pattern[i1]
ch = s[i2:i2 + i]

if ch in self.dic2:
continue

self.dic1[p] = ch
self.dic2[ch] = p
if self.wordPatternMatch(pattern, s, i1 + 1, i2 + i):
return True
del self.dic1[p]
del self.dic2[ch]
return False



精彩评论(0)

0 0 举报