7.3 - hard - 22
첫 번째 사고방식은 Recursion인데 TLE가 됐어요. DP로 한 것 같아요. DP로도 한 셈이에요. 그런데 약간의 의문이 있어요. s3을 검사할 때 1번부터 검사해야 해요. 0번이 아니라 1번부터 검사해야 해요. 생각해보면 s3[0]이 초기화할 때 이미 초기화되었어요.umm. 어쨌든 약간 tricky인 것 같아요.
class Solution(object):
def isInterleave(self, s1, s2, s3):
"""
:type s1: str
:type s2: str
:type s3: str
:rtype: bool
"""
print s1, s2, s3
if len(s3) != len(s1) + len(s2):
return False
if not s1 and not s2 and not s3:
return True
if not s1:
return s2 == s3
if not s2:
return s1 == s3
if s1[0] == s2[0]:
if s3[0] == s1[0]:
return self.isInterleave(s1[1:], s2, s3[1:]) or self.isInterleave(s1, s2[1:], s3[1:])
else:
return False
elif s1[0] == s3[0]:
return self.isInterleave(s1[1:], s2, s3[1:])
elif s2[0] == s3[0]:
return self.isInterleave(s1, s2[1:], s3[1:])
else:
return False
class Solution(object):
def isInterleave(self, s1, s2, s3):
"""
:type s1: str
:type s2: str
:type s3: str
:rtype: bool
"""
if len(s3) != len(s1) + len(s2):
return False
if not s1 and not s2 and not s3:
return True
if not s1:
return s2 == s3
if not s2:
return s1 == s3
# dp[i][j] s1 0~i s2 0~j
dp = [[False for _ in range(len(s2)+1)] for _ in range(len(s1)+1)]
dp[0][0] = True
for i in range(1, len(s1)+1):
if s1[i-1] == s3[i-1]:
dp[i][0] = True
else:
break
for i in range(1, len(s2)+1):
if s2[i-1] == s3[i-1]:
dp[0][i] = True
else:
break
for i in range(1, len(s1)+1):
for j in range(1, len(s2)+1):
if not dp[i][j]:
if s1[i-1] == s3[i+j-1] == s2[j-1]:
dp[i][j] = dp[i-1][j] or dp[i][j-1]
elif s1[i-1] == s3[i+j-1]:
dp[i][j] = dp[i-1][j]
elif s3[i+j-1] == s2[j-1]:
dp[i][j] = dp[i][j-1]
return dp[len(s1)][len(s2)]
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.