230228 올바른 괄호의 갯수

Jongleee·2023년 2월 28일
0

TIL

목록 보기
193/786
  1. 조건에 맞는 경우 직접 구하기 - deque 사용
public static int solution(int n) {
    Deque<Node> stack = new LinkedList<>();
    stack.push(new Node(0, 0));

    int count = 0;
    while (!stack.isEmpty()) {
        Node node = stack.pop();
        if (node.left > n || node.right > n || node.left < node.right) {
            continue;
        }
        if (node.left == n && node.right == n) {
            count++;
        } else {
            stack.push(new Node(node.left + 1, node.right));
            stack.push(new Node(node.left, node.right + 1));
        }
    }

    return count;
}

private static class Node {
    private final int left;
    private final int right;

    private Node(int left, int right) {
        this.left = left;
        this.right = right;
    }
}
  1. 조건에 맞는 경우 직접 구하기 - dfs 사용
public int recursive(int n) {
    count = 0;

    dfs(0, 0, n);
    return count;
}

public void dfs(int left, int right, int n) {
    if (left > n || right > n)
        return;
    if (left < right)
        return;
    if (left == n && right == n) {
        count++;
        return;
    }
    dfs(left + 1, right, n);
    dfs(left, right + 1, n);
}
  1. 괄호의 성질(카탈란 수)을 이용한 dp
public int dp(int n) {
    int[] dp = new int[n + 1];
    dp[0] = 1;
    dp[1] = 1;

    for (int i = 2; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            dp[i] += dp[i - j] * dp[j - 1];
        }
    }

    return dp[n];
}

0개의 댓글