본문 바로가기
Preparing Coding Test/Baekjoon

[Java/백준/브루트 포스] 2231 - 분해합

by weero 2020. 8. 26.

문제

https://www.acmicpc.net/problem/2231

 

2231번: 분해합

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

www.acmicpc.net

 

코드

import java.util.Scanner;

public class Main{
	public static void main(String[] args) {
		Scanner in = new Scanner(System.in);
		int decomposition = in.nextInt();
		int size = String.valueOf(decomposition).length();
	
		for(int i=decomposition-(9*size); i<decomposition; i++) { //constructor i
			int tmpDecomposition = i;
			int tmp = i;
			while(tmp>0) {
				tmpDecomposition += tmp%10;
				tmp/=10;
			}	
			
			if(tmpDecomposition == decomposition) {
				System.out.println(i);
				return;
			}
			else if(i==decomposition-1){
				System.out.println(0);
			return;
			}
		}		
	}
}