gimmickbutreal

[백준/자바] 4673번 해설 - Java 본문

Algorithm/Java

[백준/자바] 4673번 해설 - Java

isshosng 2022. 2. 11. 21:15

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

 

4673번: 셀프 넘버

셀프 넘버는 1949년 인도 수학자 D.R. Kaprekar가 이름 붙였다. 양의 정수 n에 대해서 d(n)을 n과 n의 각 자리수를 더하는 함수라고 정의하자. 예를 들어, d(75) = 75+7+5 = 87이다. 양의 정수 n이 주어졌을 때,

www.acmicpc.net

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
public class Main { 
    public static void main(String[] args) {
        boolean[] check = new boolean[10001];    
 
        for (int i = 1; i < 10001; i++){
            int n = d(i);
        
            if(n < 10001){    
                check[n] = true;
            }
        }
 
        StringBuilder sb = new StringBuilder();
        
        for (int i = 1; i < 10001; i++) {
            if (!check[i]) {    // false 인 인덱스만 출력
                sb.append(i).append('\n');
            }
        }
        System.out.println(sb);
    }
 
    public static int d(int number){
        int sum = number;
    
        while(number != 0){
            sum = sum + (number % 10);
            number = number/10;    
        }
    
        return sum;
    }
}    
cs