본문 바로가기
Algorithm/BaekJoon[Java]

백준 2133

by 씨니 2022. 3. 29.
728x90

▶ 2133문제 - 타일 채우기

 

▶ 풀이방법

import java.io.*;
public class Main {
	public static void main(String[] args) throws Exception {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
		
		int num = Integer.parseInt(br.readLine());
		int[] dp = new int[num+1];
		
		dp[0] = 1;
		if(num > 1) dp[2] = 3; // 1이하일때 런타임 에러 발생하므로 1 이상일 때만 dp[2]값 선언.
		
        //점화식 사용.
		for(int i = 4; i <= num; i+=2) {
			dp[i] = dp[i-2] * dp[2];
			for(int j = i-4; j >= 0 ; j -= 2) {
				dp[i] += (dp[j] * 2);
			}
		}
		
		bw.write(String.valueOf(dp[num]));
		bw.flush();
		bw.close();
		br.close();
	}
}
728x90

'Algorithm > BaekJoon[Java]' 카테고리의 다른 글

백준 2743  (0) 2022.03.29
백준 10820  (0) 2022.03.29
백준 10809  (0) 2022.03.25
백준 10808  (0) 2022.03.25
백준 10824  (0) 2022.03.25