티스토리 뷰

반응형

문제

 

2231번: 분해합

어떤 자연수 N이 있을 때, 그 자연수 N의 분해합은 N과 N을 이루는 각 자리수의 합을 의미한다. 어떤 자연수 M의 분해합이 N인 경우, M을 N의 생성자라 한다. 예를 들어, 245의 분해합은 256(=245+2+4+5)이

www.acmicpc.net

풀이

완전탐색 (브루트포스)를 통해서 풀 수 있다. 

import sys

N = int(sys.stdin.readline())

flag = 0
for i in range(1, N+1):
    total = i

    string = str(i)
    for j in range(len(string)):
        total += int(string[j])

    if total == N:
        flag = 1
        print(i)
        break

if flag == 0:
    print(0)

반응형