ps | |
---|---|
링크 | programmers.co.kr/… |
출처 | 프로그래머스 |
문제 번호 | 42895 |
문제명 | N으로 표현 |
레벨 | Level 3 |
분류 |
DP |
시간복잡도 | O(n^2*m*10^m) |
인풋사이즈 | n<=9, m<=8 |
사용한 언어 | Python |
해결날짜 | 2020/11/30 |
태그 |
"""Solution code for "Programmers 42895. N으로 표현".
- Problem link: https://programmers.co.kr/learn/courses/30/lessons/42895
- Solution link: http://www.teferi.net/ps/problems/programmers/42895
"""
MAX = 8
def solution(N, number):
dp = [set() for _ in range(MAX + 1)]
dp[0] = {0}
for i in range(1, MAX + 1):
dp[i] = {int(str(N) * i)}
for j in range(1, i):
for n1 in dp[j]:
for n2 in dp[i - j]:
dp[i] |= {n1 + n2, n1 - n2, n1 * n2}
if n2 != 0:
dp[i].add(n1 // n2)
if number in dp[i]:
return i
return -1