본문 바로가기
알고리즘!/Dynamic Programming

[C] 1003: 피보나치 함수

by soeayun 2023. 8. 3.

피보나치!!하면 바로 Dynamic Programming으로 풀어야겠다는 생각이 들어야한다!

가장 대표적이면서 기본적인 DP 문제가 피보나치랑 이항계수 관련된 문제이기 때문이다

 

예시와 같이 피보나치 함수를 f(n)부터 구한다면 호출의 개수가 n이 조금만 증가해도 기하급수적으로 늘어난다.

그렇기 때문에 f(0)과 f(1) 부터 배열에 저장하면서 f(n)을 구해야만 효율적으로 호출할 수 있다.

 

이 문제에서도 n이 1,2,3...증가할 수록 호출하는 f(0)과 f(1)의 개수가 피보나치 수열의 점화식을 따른다.

그렇기 때문에 이것을 배열에 미리 저장한 후 테스트케이스가 주어지면 불러오면 되는것이다

 

#include <stdio.h>

int arr[500001];

int fibo_0[41];
int fibo_1[41];

  int main(void)
  {
   
    int t;
    scanf("%d",&t);
    fibo_0[0]=1;
    fibo_1[0]=0;
    fibo_0[1]=0;
    fibo_1[1]=1;
    for(int i=2;i<=40;i++)
      {
        fibo_0[i]=fibo_0[i-1]+fibo_0[i-2];
        fibo_1[i]=fibo_1[i-1]+fibo_1[i-2];
      }

    for(int i=1;i<=t;i++)
      {
        int tmp;
        scanf("%d",&tmp);
        printf("%d %d\n",fibo_0[tmp],fibo_1[tmp]);
      }
    
  }

'알고리즘! > Dynamic Programming' 카테고리의 다른 글

[C] 2293: 동전 1  (1) 2023.08.21
[C] 1929: 소수 구하기  (0) 2023.08.10
[C] 2748: 피보나치 수 2  (0) 2023.07.30
[C] 1149: RGB거리  (0) 2023.07.30
11727: 2Xn 타일링 2  (0) 2023.07.29