-
Notifications
You must be signed in to change notification settings - Fork 43
/
isomorphic-strings.py
128 lines (118 loc) · 3.23 KB
/
isomorphic-strings.py
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
# Time: O(n)
# Space: O(1)
# Given two strings s and t, determine if they are isomorphic.
#
# Two strings are isomorphic if the characters in s can be replaced to get t.
#
# All occurrences of a character must be replaced with another character
# while preserving the order of characters. No two characters may map to
# the same character but a character may map to itself.
#
# For example,
# Given "egg", "add", return true.
#
# Given "foo", "bar", return false.
#
# Given "paper", "title", return true.
#
# Note:
# You may assume both s and t have the same length.
# V0
# V1
# https://blog.csdn.net/liuxiao214/article/details/77587070
# IDEA : HASH TABLE
class Solution(object):
def isIsomorphic(self, s, t):
"""
:type s: str
:type t: str
:rtype: bool
"""
def sub(s,t):
m={}
for i in range(len(s)):
if s[i] not in m.keys():
m[s[i]]=t[i]
else:
if m[s[i]]!=t[i]:
return False
return True
return sub(s, t) and sub(t,s)
# V1'
# https://blog.csdn.net/liuxiao214/article/details/77587070
# IDEA : MAPPING + ORD
class Solution1(object):
def isIsomorphic(self, s, t):
"""
:type s: str
:type t: str
:rtype: bool
"""
a1=[-1]*256
a2=[-1]*256
for i in range(len(s)):
if a1[ord(s[i])] != a2[ord(t[i])]:
return False
a1[ord(s[i])]=i
a2[ord(t[i])]=i
return True
# V1''
# https://www.jiuzhang.com/solution/isomorphic-strings/#tag-highlight-lang-python
class Solution:
"""
@param s: a string
@param t: a string
@return: true if the characters in s can be replaced to get t or false
"""
def isIsomorphic(self, s, t):
# write your code here
map1 = {}
map2 = {}
for i in range(len(s)):
if s[i] not in map1:
map1[s[i]] = t[i]
elif map1[s[i]] != t[i]:
return False
for i in range(len(t)):
if t[i] not in map2:
map2[t[i]] = s[i]
elif map2[t[i]] != s[i]:
return False
return True
# V2
# Time: O(n)
# Space: O(1)
from itertools import izip # Generator version of zip.
class Solution(object):
def isIsomorphic(self, s, t):
"""
:type s: str
:type t: str
:rtype: bool
"""
if len(s) != len(t):
return False
s2t, t2s = {}, {}
for p, w in izip(s, t):
if w not in s2t and p not in t2s:
s2t[w] = p
t2s[p] = w
elif w not in s2t or s2t[w] != p:
# Contradict mapping.
return False
return True
# Time: O(n)
# Space: O(1)
class Solution2(object):
def isIsomorphic(self, s, t):
if len(s) != len(t):
return False
return self.halfIsom(s, t) and self.halfIsom(t, s)
def halfIsom(self, s, t):
lookup = {}
for i in range(len(s)):
if s[i] not in lookup:
lookup[s[i]] = t[i]
elif lookup[s[i]] != t[i]:
return False
return True