Problem
n
개의 균형 잡힌 괄호를 이루는 문자열의 모든 케이스를 구하는 문제입니다.
Solution
재귀를 사용하면 됩니다.
여는 괄호 (
를 붙이는 경우와 닫는 괄호 )
를 붙이는 경우에 따라서 재귀로 들어갑니다.
open
변수는 열 수 있는 괄호의 갯수, close
변수는 닫을 수 있는 괄호의 갯수입니다.
균형 잡힌 괄호를 만들어야 하기 때문에 close
변수는 open
변수보다 클 때만 붙일 수 있습니다.
만약 닫는 괄호가 더 많이 사용된 상태라면 이미 균형 잡힌 괄호가 아닙니다.
open
변수와 close
변수를 전부 사용해서 0 이 되버리면 문자열 s
를 결과 리스트에 담습니다.
Java Code
class Solution {
public List<String> generateParenthesis(int n) {
List<String> res = new ArrayList<>();
recursive(res, "(", n - 1, n);
return res;
}
public void recursive(List<String> res, String s, int open, int close) {
if (open == 0 && close == 0) {
res.add(s);
return;
}
if (open > 0) {
recursive(res, s + "(", open - 1, close);
}
if (close > open) {
recursive(res, s + ")", open, close - 1);
}
}
}
'알고리즘 문제 > LeetCode' 카테고리의 다른 글
[LeetCode Easy] Contains Duplicate (Java, Kotlin) (0) | 2020.11.21 |
---|---|
[LeetCode Easy] Valid Anagram (Java, Kotlin) (0) | 2020.11.21 |
[LeetCode Medium] Binary Tree Inorder Traversal (Java, Kotlin) (0) | 2020.11.15 |
[LeetCode Medium] Permutations (Java, Kotlin) (0) | 2020.11.15 |
[LeetCode Easy] Fizz Buzz (Java, Kotlin) (0) | 2020.11.13 |