Question
Given a pattern
and a string str
, find if str
follows the same pattern.
Here follow means a full match, such that there is a bijection between a letter in pattern
and a non-empty word in str
.
Examples:
- pattern = “abba”, str = “dog cat cat dog” should return true.
- pattern = “abba”, str = “dog cat cat fish” should return false.
- pattern = “aaaa”, str = “dog cat cat dog” should return false.
- pattern = “abba”, str = “dog dog dog dog” should return false.
Notes:
You may assume pattern
contains only lowercase letters, and str
contains lowercase letters separated by a single space.
Solution
Result: Accepted Time: 40 ms
Here should be some explanations.
class Solution(object):
def wordPattern(self, pattern, str):
"""
:type pattern: str
:type str: str
:rtype: bool
"""
words = str.split(' ')
cnt = len(words)
if cnt <> len(pattern):
return False
mp1={}
mp2={}
for i in xrange(cnt):
if pattern[i] not in mp1:
mp1[pattern[i]] = words[i]
elif mp1[pattern[i]] <> words[i]:
return False
if words[i] not in mp2:
mp2[words[i]] = pattern[i]
elif mp2[words[i]] <> pattern[i]:
return False
return True
Complexity Analytics
- Time Complexity: O(n)
- Space Complexity: O(1)