Hyemi Lee

Hyemi Lee

주니어 개발자의 삽질과 기록

Algorithm, Catalan Number

카탈란 수

1. 잘 짜인 괄호

  • 괄호 ()를 잘 짜였다고한다. n쌍의 ()를 잘 짜인 모양으로 늘어 놓는 방법은 몇가지인가?
    n=0 , *
    n=1 , ()
    n=2 , ()(), (())
    ...
    

2. 산만들기

  • 오르막과 내리막을 n쌍으로 산을 만들수있는 방법의 수는?
    n=0 , *
    n=1 , /\
     /\
    n=2 , /\/,円 / \
    

3. 대각선 피해가기

  • 정사각형으로 이루어진 nxn개의 정사각형의 변을 따라 이동할때 대각선과 만나지 않고 이동하는 방법의 수? ( 산만들기과 같은 문제이다 )

4. 다각형을 삼각형으로 나누기

  • n+2개 변으로 이루어진 볼록 다각형을 서로 만나지 않는 대각선을 사용해서 n개의 삼각형으로 나누는 방법의 수

점화식 찾기

  • AB가 n-1쌍의 괄호를 가질때 n쌍의 괄호로 만들수있는 방법은 ()AB, (A)B, A(B), (AB)가 있다.
  • A가 k쌍이면, B는 n-k-1쌍이 있어야 한다.
C1 = C0C0
C2 = C0C1 + C1C0
C3 = C0C2 + C1C1 + C2C0
...

boj 10422 괄호

package org.baekjoon;
import java.util.Scanner;
public class test10422 {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int T = sc.nextInt();
		long[] dp = new long[2501];	// dp[i] : 괄호 i쌍의 개수. 길이6은 3쌍을 만들수있다.
		dp[0] = 1;
		dp[1] = 1;
		for (int i = 2; i <= 2500; i++) {
			for (int j = 0; j < i; j++) {
				dp[i] += (dp[j] * dp[i - j - 1]) ;
				dp[i] %= 1000000007;
			}
		}
		while (T-- > 0) {
			int n = sc.nextInt();
			if (n % 2 != 0) {
				System.out.println(0);
				continue;
			}
			System.out.println(dp[n/2]);
		}
	}
}

코드표현

package org.study;
public class CatalanNumber {
	static int[] dp;
	public static void main(String[] args) {
		int N = 10;
		for (int i = 1; i <= N; i++) {
			System.out.println(catalan(i));
		}
		System.out.println();
		dp = new int[N + 1];
		dp[0] = 1;
		dp[1] = 1;
		for (int i = 2; i <= N; i++) {
			for (int j = 0; j < i; j++) {
				dp[i] += dp[j] * dp[i - j - 1];
			}
			System.out.println(dp[i]);
		}
	}
	static int catalan(int n) {
		int res = 0;
		// base case
		if (n <= 1) {
			return 1;
		}
		for (int i = 0; i < n; i++) {
			res += catalan(i) * catalan(n - i - 1);
		}
		return res;
	}
}
1, 2, 5, 14, 42, 132, 429, 1430, 4862, 16796

참고

Share on

Twitter Facebook LinkedIn

You may also enjoy

Redis Stream

2021年04月28日

Stream Stream은 로그 데이터를 처리하게위해 5.0에서 새로 도입된 데이터 타입입니다. 대량의 데이터가 연속적으로 발생할때 처리하기 위해 등장했습니다. 기존 데이터를 수정하지 않고 오직 추가로 발생합니다. 이런 종류의 데이터를 stream or log데이터...

Study, Object, chapter2&3 presentation

2021年04月20日

chapter03. 역할, 책임, 협력 객체지향 설계란, 올바른 객체에게 올바른 책임을 할당하면서 낮은 결합도와 높은 응집도를 가진 구조를 창조하는 활동이다.

Spring, chatting 프로그램 만들기, Reactive란?

2020年06月16日

Reactive 막힘없이 흘러다니는 data(event)를 통해 사용자에게 자연스러운 응답을 주고 규모 탄력적으로 리소스를 사용하며 실패에 있어서 유연하게 대처한다 모든 지점에서 블럭 되지 않게 하자 oop와 같은 패러다임 모든 것을 비동기적인 data의 strea...