[BOJ / C++] 이친수 (다이나믹 프로그래밍)

2025. 8. 3. 00:23·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/2193

 

1. 코드

#include <bits/stdc++.h>
using namespace std;

using ll = long long;

int main() {
    ios::sync_with_stdio(0); cin.tie(0);

    int n;
    cin >> n;

    vector<vector<ll>> d(92, vector<ll>(2, 0));
    d[1][0] = 0;
    d[1][1] = 1;
    for (int i = 2; i <= 90; i++) {
        d[i][0] = d[i-1][0] + d[i-1][1];
        d[i][1] = d[i-1][0];
    }

    cout << d[n][0] + d[n][1];
}

 

 

2. 시간복잡도

90번만 연산하면 끝나므로 시간제한 2초 안에 해결 가능하다.

 

 

3. 분석

1. dp 테이블

(1) 끝에가 0인 경우: 앞에 1, 0 모두 올 수 있음.

(2) 끝에가 1인 경우: 앞에 0만 올 수 있음, 1이 2개 연속 올 수 없기 때문에

 

2. 점화식

d[i][0] = d[i-1][0] + d[i-1][1];

d[i][1] = d[i-1][0];

 

vector의 자료형이 int가 되면 int overflow가 발생한다. dp에서 피보나치 형식의 덧셈이 될 경우 40만 넘어가도 int overflow가 될 확률이 높다. long long 자료형을 쓰도록 하자!

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ 14891 / C++] 톱니바퀴 (시뮬레이션)  (0) 2025.08.04
[BOJ / C++] 홍익 투어리스트 (이진검색트리)  (0) 2025.08.03
[BOJ / C++] 수강신청 (해시)  (0) 2025.08.02
[BOJ / C++] 문제 추천 시스템 Version 2 (이진검색트리)  (0) 2025.08.02
[BOJ / C++] 문제 추천 시스템 Version 1 (이진검색트리)  (0) 2025.08.01
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ 14891 / C++] 톱니바퀴 (시뮬레이션)
  • [BOJ / C++] 홍익 투어리스트 (이진검색트리)
  • [BOJ / C++] 수강신청 (해시)
  • [BOJ / C++] 문제 추천 시스템 Version 2 (이진검색트리)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (174) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (17) N
        • Java (8)
        • Spring (4)
        • Docker (4)
        • AI Agent (1) N
      • 코딩테스트 (96) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (13) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 이친수 (다이나믹 프로그래밍)
상단으로

티스토리툴바