ezhoon

[백준] 4673_셀프 넘버_Java 본문

[Java] 백준 문제풀이/함수

[백준] 4673_셀프 넘버_Java

ezhoon 2022. 1. 9. 22:37

백준 4673

 

4673번: 셀프 넘버

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

www.acmicpc.net

 

⚠️주의사항

  • 셀프넘버가 어떤 개념인지 이해할 것
  • 한 줄에 한개씩만 출력 
    • sb.append(value).append("\n") 식으로 출력

문제풀이


public class class_4673 {

    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]) {
                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; // 10으로 나누어 첫 째 자리를 없앤다.
        }
        return sum;
    }
}

이번 문제는 내가 직접 푼 답은 너무 형편이 없어서 다른 사람들은 어떻게 풀었나 검색 중에 너무 잘 푼 코드가 있어서 이 코드를 가져와봤다.

 

출처

'[Java] 백준 문제풀이 > 함수' 카테고리의 다른 글

[백준] 15596_정수 N개의 합_Java  (0) 2022.01.09
Comments