녕의 학습 기록

백준_2193 이친수 (DP) 본문

Algorithm/Algorithm 문제

백준_2193 이친수 (DP)

kjyyjk 2024. 4. 14. 17:13

 

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

public class BJ_2193_이친수 {

    public static void main(String[] args) throws IOException {

        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

        int n = Integer.parseInt(br.readLine());

        long[][] d = new long[n+1][2]; //d[i][0] : i번째의 0의 개수, d[i][1] : i번째의 1의 개수
        d[1][0] = 0;
        d[1][1] = 1;

        for (int i=2; i<n+1; i++) {
            d[i][0] = d[i-1][0] + d[i-1][1]; //이전 0 개수 + 이전 1 개수
            d[i][1] = d[i-1][0]; // 이전 0 개수
        }

        long result = d[n][0] + d[n][1];
        System.out.println(new StringBuilder().append(result));
    }
}
 

2193번: 이친수

0과 1로만 이루어진 수를 이진수라 한다. 이러한 이진수 중 특별한 성질을 갖는 것들이 있는데, 이들을 이친수(pinary number)라 한다. 이친수는 다음의 성질을 만족한다. 이친수는 0으로 시작하지 않

www.acmicpc.net

 

'Algorithm > Algorithm 문제' 카테고리의 다른 글

백준_10844 쉬운 계단 수 (DP)  (0) 2024.04.16
백준_11726 2xn 타일링 (DP)  (0) 2024.04.15
백준_14501 퇴사 (DP)  (0) 2024.04.13
백준_1463 1로 만들기 (DP)  (0) 2024.04.11
백준_1947 선물 전달 (조합 순열)  (0) 2024.04.08