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