초보개발자

[2225] 합분해 본문

알고리즘/문제해결 소스코드

[2225] 합분해

___yejin 2017. 9. 28. 20:48
  • 입력: 표현하려는 숫자 N(1≤N≤200), 양수의 개수 K(1≤K≤200)
  • 출력: 자연수 N을 K개의 양수로 표현할 수 있는 방법의 수(숫자 순서가 다르면 다른 경우)
  • 알고리즘: 동적 계획법
  • 소스코드
    간단히 예를 들면 4로 3개의 양수로 표현하는 방법(이하 [4,3]이라 표현)을 설명을 하면 다음과 같다.
    우선, 모든 숫자는 1개의 양수로 표현할 수 있는 방법은 1가지씩 갖고 있다. 
    4 = 0 + [4,2] 호출 
      = 1 + [3,2] 호출
      = 2 + [2,2] 호출
      = 3 + [1,2] 호출
      = 4 + [0,2] 호출
    이때, [4,2]에서 반복적으로 [4,1],[3,1],[2,1],[1,1],[0,0]을 호출한다. 총 5개이다.
    문제를 풀면서 알았는데, 똑같은 숫자가 여러번 나와도 되는 모양이다.


'알고리즘 > 문제해결 소스코드' 카테고리의 다른 글

[11376] 열혈 강호2  (0) 2017.10.03
[11727] 2xn 타일링 2  (0) 2017.09.28
[2293] 동전1  (0) 2017.09.16
[1010] 다리 놓기  (0) 2017.09.16
[2167] 2차원 배열의 합  (0) 2017.09.16
Comments