라이브러리는 도서관 아닌가요

백준 (BOJ) 2705 팰린드롬 파티션 java dp 본문

알고리즘 문제

백준 (BOJ) 2705 팰린드롬 파티션 java dp

veryhi 2022. 5. 10. 19:50

 

https://www.acmicpc.net/problem/2705

 

2705번: 팰린드롬 파티션

첫째 줄에 테스트 케이스의 개수 T(1 <= T <= 1,000)가 주어진다. 각 테스트 케이스는 양의 정수 1개로 이루어져있고, 이 수가 문제에서 설명한 N이고, 1,000보다 작거나 같다.

www.acmicpc.net

 

수를 나열한 후 살펴봐도 처음 아이디어를 얻기가 쉽지 않았던 문제

 

팰린드롬 파티션은 양쪽 파티션 합이 짝수일 때만 발생한다는 특징이 있다.

 

< 1의 경우 >

1

 

< 2의 경우 >

1 1
 2

 

< 3의 경우 >
1 1 1
  3

 

< 4의 경우 >

1 1 1 1
 1 2 1 
  2 2  
   4

 

< 8의 경우 >

1 1 1 1 1 1 1 1   ( (8-0)/2 == 4 )
  1 2 1 1 2 1      ( (8-0)/2 == 4 )
 1 1 1 2 1 1 1     ( (8-2)/2 == 3 )
      3 2 3          ( (8-2)/2 == 3 ) 
     2 2 2 2        ( (8-0)/2 == 4 )
    1 1 4 1 1       ( 2 )
      2 4 2          ( 2 )
       4 4            ( (8-0)/2 == 4 )
      1 6 1          ( 1 )
        8             ( dp[0] )

 

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br= new BufferedReader(new InputStreamReader(System.in));

        // N 최대 1000
        int[] dp = new int[1001];
        int diff;

        for(int i=1; i<1001; ++i){
            dp[i] = 1;
            for(int j=0; j<i; ++j){ // 짝수/홀수 두 경우이므로 0, 1 모두 필요
                diff = i-j;
                if((diff & 1) != 1) { // 홀수 아닐 떄만
                    dp[i] += dp[diff >> 1];
                }
            }
        }

        int T, N;
        T = Integer.parseInt(br.readLine());
        StringBuilder sb = new StringBuilder();
        for(int t=0; t<T; ++t){
            N = Integer.parseInt(br.readLine());
            sb.append(dp[N]).append("\n");
        }
        System.out.print(sb);

    }
}

 

비트로 (0000...0001)인 1과 특정 정수를 & 연산을 사용해서 홀짝 판별을 쉽게 할 수 있다.

 

Comments