/ BACKEND

프로그래머스 코딩테스트 - 'N으로 표현' 문제 해설 (dynamic programming)

코테의 기본! Algorithm 강좌 및 실습

문제 풀기

dynamic programming을 활용하는 문제입니다~!

🧐keypoint

  • 사용횟수가 1 일때, 사용횟수가 2 일 때 경우의 수들을 정리해 보는것이 첫번째 아이디어이다.
  • 사용횟수가 2 인 집합은 사용횟수 1,사용횟수 1 인 집합을 합쳐 만들어낼 수 있다. 횟수 2,3,4 모두 마찬가지다.
  • N을 9번 이상 쓰지 않으니 경우의 수가 그리 많지는 않다..!(초반에 구상과정에서 너무 많을 것 같다는 생각이 사고 전개를 가로막았다)

N = 3이라고 가정할 경우

  • 1회 조합으로 만들어 낼 수 있는 수 : 3
  • 2회 조합으로 만들어 낼 수 있는 수 : 6(3+3), 1(3/3), 9(3*3), 33(연속)

코드!

회고

  • 코드의 x+y =i_half 부분과 반으로 나누는 이유에 대해서 복습 시 코드 면밀 검토

    Reference

  • https://www.hamadevelop.me/algorithm-n-expression/