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 |