[leetcode][44] Wildcard Matching 문제풀기!
👓 문제 요약
간단한 정규식 패턴을 줄게.
- ‘?’ 이건 하나의 문자를 대체할 수 있는 놈이야.
- ‘*’ 임마 이거는 빈 문자를 포함해서 문자열을 대체할 수 있는 놈이야.
자 이제 내가 문자열을 줄테니까 이전에 준 패턴으로 만들 수 있는 놈인지 판단해줘!
자세한 문제 설명과 릿코드 홈페이지 참고. 문제풀러가기
🔑 문제 풀이
문제에서 문자열의 길이와 패턴의 길이가 최대 2,000 이기 때문에 O(n^2) 으로도 가능한 문제입니다!!
저는 DP 기법으로 풀었습니다.
dp[i][j] 는 0 ~ i - 1 까지의 패턴으로, 0 ~ j - 1 까지의 문자열을 만족할 수 있는지에 대한 정보를 나타냅니다.
이 문제의 경우 패턴의 인덱스가 0 이거나 문자열의 인덱스가 0 인 경우에 대한 처리가 복잡해질거 같아서
인덱스를 하나씩 더 써서 사용 했습니다. 즉 dp[0][0] 은 패턴 0개, 문자열 0개를 사용했을 때를 나타냅니다.
검사하려는 i - 1 의 패턴이 ‘*’ 인 경우와 ‘?’ 또는 알파벳문자 인 경우로 나누었습니다.
- ‘*’ 인 경우 : 이 경우는 즉 현재 패턴을 뺀 경우 또는 현재 검사하려는 문자열에서 마지막 문자를 뺀 경우가 만족하면 true 입니다. -> dp[i - 1][j] 또는 dp[i][j - 1] 가 true 이면 dp[i][j] 는 true
- ‘?’ 또는 알파벳문자 인 경우 : 이 경우는 현재 패턴과 검사하려는 문자열의 마지막 문자를 뺀 경우 만족하면 true 입니다. -> dp[i - 1][j - 1] 가 true 이면 dp[i][j] 는 true
🥽 소스코드 및 소스해석
var isMatch = function (s, p) {
//remove consecutive star e.g) **
if (p.length === 0 && s.length === 0) return true;
if (p.length === 0) return false;
let patternTemp = new Array();
for (let i = 0; i < p.length; i++) {
while (i + 1 < p.length && p[i] === "*" && p[i + 1] === "*") i++;
patternTemp.push(p[i]);
}
p = patternTemp;
// dp[i][j] measn from p[0] ~ p[i]
let dp = new Array(p.length + 1);
for (let i = 0; i <= p.length; i++) {
dp[i] = new Array(s.length + 1);
dp[i].fill(false);
}
//dp[pattern][string]
dp[0][0] = true;
dp[1][0] = p[0] === "*" ? true : false;
for (let patternIdx = 1; patternIdx <= p.length; patternIdx++) {
for (let stringIdx = 1; stringIdx <= s.length; stringIdx++) {
if (p[patternIdx - 1] === "*") {
dp[patternIdx][stringIdx] =
dp[patternIdx][stringIdx - 1] || dp[patternIdx - 1][stringIdx];
} else if (
p[patternIdx - 1] === "?" ||
p[patternIdx - 1] === s[stringIdx - 1]
) {
dp[patternIdx][stringIdx] = dp[patternIdx - 1][stringIdx - 1];
}
}
}
return dp[p.length][s.length];
🔨 문제 후기
처음에 패턴이 0 인 경우 문자열이 0 인 경우 다 나누고 있다가 이게 뭔 짓이람 하고 인덱스를 하나 늘려서 그냥 저장했더니 더 간결해졌다.
항상 알고리즘이 동일하다면 더 간결하게 쓰기 위해 노력해야겠다!!
Series
Algorithms
이 글은 "Algorithms" 시리즈의 26번째 기록입니다.
- 01#[프로그래머스][연습문제] 3 x N 타일링 풀이
- 02[프로그래머스][2019 kakao] 블록게임 해설
- 03[프로그래머스][2019 kakao] 길 찾기 게임 문제 해설
- 04[프로그래머스][2019 kakao] 무지의 먹방 라이브 문제 해설
- 05[프로그래머스][2019 kakao] 후보키 문제 해설
- 06[프로그래머스✈][2020 kakao] 자물쇠와 열쇠 문제 풀이
- 07[프로그래머스][2020 kakao] 기둥과 보 설치 문제 해설
- 08[프로그래머스✈][2020 kakao] 가사 검색 문제 풀이
- 09[백준🔉][16234] 인구이동 문제 해설
- 10[프로그래머스✈][2019 kakao 겨울 인턴십] 불량 사용자 문제 해설
- 11[프로그래머스✈][2020 kakao] 동굴 탐험
- 12[백준🔉][14501] 퇴사 문제 해설
- 13[프로그래머스✈][2017 카카오코드] 4단 고음 해설
- 14[프로그래머스✈][2019 kakao 겨울 인턴쉽] 징검다리 건너기 해설
- 15[프로그래머스✈][연습문제] 섬 연결하기 풀이
- 16[leetcode][15] 3sum 문제풀기!
- 17[leetcode][16] 3sum closet 문제풀기!
- 18[📣top interview question] Remove Duplicates from Sorted Array Solution 문제풀기!
- 19[📣top interview question] Best Time to Buy and Sell Stock II 문제풀기!
- 20[leetcode][30] Substring with Concatenation of All Words 문제풀기!
- 21[leetcode][31] Next Permutation 문제풀기!
- 22[leetcode][32] Longest Valid Parentheses 문제풀기
- 23[leetcode][40] Combination Sum II 문제풀기!
- 24[leetcode][42] Trapping Rain Water 문제풀기!
- 25[leetcode][43] Multiply Strings 문제풀기!
- 26[leetcode][44] Wildcard Matching 문제풀기!
- 27[leetcode][45] Jump Game II 문제풀기!