240320 산 모양 타일링

Jongleee·2024년 3월 20일
0

TIL

목록 보기
525/683
private static final int MOD = 10007;
    
public int solution(int n, int[] tops) {
	int[][] dp = new int[n + 1][2];
	dp[0][1] = 1;
	
	for (int i = 0; i < n; i++) {
		int top = tops[i];
		int k = i + 1;
		dp[k][0] = (dp[i][0] + dp[i][1]) % MOD;
		if (top == 0) {
			dp[k][1] = (dp[i][0] + dp[i][1] * 2) % MOD;
		} else {
			dp[k][1] = (dp[i][0] * 2 + dp[i][1] * 3) % MOD;
		}
	}
	
	return (dp[n][0] + dp[n][1]) % MOD;
}

출처:https://school.programmers.co.kr/learn/courses/30/lessons/258705

0개의 댓글