Dev.baelanche

[백준 11727] 2xn 타일링 2 본문

Data Structure & Algorithm/PS - JAVA

[백준 11727] 2xn 타일링 2

baelanche 2019. 4. 2. 19:56
반응형

 

경우의 수를 구해보면 f(n) = 2(fn-2) + (f-1) 이다. 동적계획법으로 풀면 된다.

 

 

 

public static int[] dp;
    
    public static int f(int n) {
        if(n == 0) {dp[0] = 0; return 0;}
        if(n == 1) {dp[1] = 1; return 1;}
        if(n == 2) {dp[2] = 3; return 3;}
        if(n == 3) {dp[3] = 5; return 5;}
        if(dp[n] != -1) return dp[n];
        
        int result = 2*(f(n-2)%10007) + f(n-1)%10007;
        dp[n] = result;
        return result;
    }
    
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        
        int n = sc.nextInt();
        dp = new int[n+1];
        
        for(int i=0; i<dp.length; i++)
            dp[i] = -1;
        
        System.out.println(f(n)%10007);
}

 

(A+B)%M = (A%M+B%M)%M 에 대한 증명은

https://baelanche.tistory.com/17 에 있다.

반응형

'Data Structure & Algorithm > PS - JAVA' 카테고리의 다른 글

[백준 9012] 괄호  (0) 2019.04.03
[백준 10828] 스택  (0) 2019.04.03
[백준 11726] 2xn 타일링  (0) 2019.04.02
[백준 1904] 01타일  (0) 2019.04.02
[백준 2193] 이친수  (0) 2019.04.02
Comments