forked from kamyu104/LeetCode-Solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpalindrome-partitioning-iv.py
63 lines (59 loc) · 1.77 KB
/
palindrome-partitioning-iv.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
# Time: O(n^2)
# Space: O(n)
class Solution(object):
def checkPartitioning(self, s):
"""
:type s: str
:rtype: bool
"""
def manacher(s):
s = '^#' + '#'.join(s) + '#$'
P = [0]*len(s)
C, R = 0, 0
for i in xrange(1, len(s)-1):
i_mirror = 2*C-i
if R > i:
P[i] = min(R-i, P[i_mirror])
while s[i+1+P[i]] == s[i-1-P[i]]:
P[i] += 1
if i+P[i] > R:
C, R = i, i+P[i]
return P
P = manacher(s)
prefix, suffix = [], []
for i in xrange(2, len(P)-2):
if i-1-P[i] == 0:
prefix.append(i)
if i+1+P[i] == len(P)-1:
suffix.append(i)
for i in prefix:
for j in suffix:
left, right = i+1+P[i], j-1-P[j]
if left > right:
continue
mid = left + (right-left)//2
if P[mid] >= mid-left:
return True
return False
# Time: O(n^2)
# Space: O(n^2)
class Solution2(object):
def checkPartitioning(self, s):
"""
:type s: str
:rtype: bool
"""
dp = [[False]*len(s) for _ in xrange(len(s))]
for i in reversed(xrange(len(s))):
for j in xrange(i, len(s)):
if s[i] == s[j] and (j-i < 2 or dp[i+1][j-1]):
dp[i][j] = True
for i in xrange(1, len(s)-1):
if not dp[0][i-1]:
continue
for j in xrange(i+1, len(s)):
if not dp[j][-1]:
continue
if dp[i][j-1]:
return True
return False