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

[C] 11726: 2Xn 타일링

by soeayun 2023. 7. 25.

생각보다 쉽게 풀려서 깜짝 놀랐다

아무래도 평소에 조금 더 어려운 문제를 푸느라 상대적으로 쉽게 느껴졌나보다!

아무래도 점화식도 피보나치 수열과 같은 형태라 생각이 떠올리기 쉬웠고 점화식형태도 하나라서 직관적으로 보였다.

 

무엇보다 구현도 간단했는데 다만 주위해야할건 입력값이 1000개인데 피보나치 수열의 특성상

f(1000)은 int의 범위에서 벗어난다. 아마 long long int를 써도 벗어날 것 이다,

 

따라서 이때 생각났던 문제가 nCr, 조합 관련 문제였는데 이것도 n!이 n이 커질수록 기하급수적으로 커지기 때문에

n-i를 곱할때 i만큼 동시에 나눠져야 범위를 벗어나지 않는다.

이것도 마찬가지로 10007을 넘어갈 때마다 10007로 나눈 나머지를 dp[]에 넣어주면 된다.

 

다음은 아래 소스코드이당!

 

#include <stdio.h>

int dp[1001];
  int main(void)
  {
    int n;
    scanf("%d",&n);
    dp[1]=1;
    dp[2]=2;
    for(int i=3;i<=n;i++)
    {
      dp[i]=dp[i-2]+dp[i-1];
      if(dp[i]>=10007)
        dp[i]=dp[i]%10007;
    }
    printf("%d",dp[n]);
  }

 

 

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

[C] 1149: RGB거리  (0) 2023.07.30
11727: 2Xn 타일링 2  (0) 2023.07.29
[C] 2156: 포도주 시식  (0) 2023.07.24
[C] 9461: 파도반 수열  (0) 2023.07.23
[C] 1912: 연속합  (0) 2023.07.23