CS/알고리즘
백준 - 분해합(2231)
sliver__
2021. 11. 19. 23:46
728x90
https://www.acmicpc.net/problem/2231
2231번: 분해합
어떤 자연수 N이 있을 때, 그 자연수 N의 분해합은 N과 N을 이루는 각 자리수의 합을 의미한다. 어떤 자연수 M의 분해합이 N인 경우, M을 N의 생성자라 한다. 예를 들어, 245의 분해합은 256(=245+2+4+5)이
www.acmicpc.net
주어진 자연수 n의 분해합을 구하는 문제이다.
분해합은 어떠한 자연수 n과 각자리의 숫자의 합을 의미한다.
n이 1,000,000까지이므로 모두 순회하며 구핻조 2초안으로 구할 수 있다.
제출한 코드는 아래와 같습니다.
#include <iostream>
using namespace std;
int main(void)
{
int n, sum, temp, res;
cin >> n;
for (int i = 1; i <= 1000000; i++)
{
sum = i;
temp = sum;
while (temp)
{
sum += (temp % 10);
temp /= 10;
}
if (n == sum)
{
res = i;
break;
}
}
cout << res;
}
728x90