728x90
문제
양의 정수 N의 디지털 루트를 구하려면 N을 이루고 있는 모든 자리수를 더해야 한다. 이때, 더한 값이 한 자리 숫자라면, 그 수가 N의 디지털 루트가 된다. 두 자리 이상 숫자인 경우에는 다시 그 수를 이루고 있는 모든 자리수를 더해야 하며, 한 자리 숫자가 될 때 까지 반복한다.
24의 디지털 루트를 구해보자. 2+4=6이다. 6은 한 자리 숫자이기 때문에, 24의 디지털 루트는 6이 된다. 39의 경우에는 3+9=12이기 때문에, 한 번 더 더해야 한다. 따라서, 1+2=3이 디지털 루트가 된다.
양의 정수 N이 주어졌을 때, 그 수의 디지털 루트를 구하는 프로그램을 작성하시오.
입력
한 줄에 하나씩 양의 정수가 주어진다. 입력의 마지막 줄은 0으로 나타낸다. 수는 최대 1000자리이다.
출력
입력으로 주어진 양의 정수의 디지털 루트를 한 줄에 하나씩 주어진 순서대로 출력한다.
풀이
N을 입력받아 한 자릿수가 될 때까지 모든 자릿수를 더해야 한다.
처음에는 N이 최대 1000자리(9999999999999999....)가 될 수 있다. 문자열로 입력받아주고 종료 조건을 설정하자.
N의 모든 자릿수를 더하면 최대 9 * 1000이 되므로 int로 담아낼 수 있다.
모든 자릿수를 더해주고, 한 자릿수가 아니라면 다시 재귀호출하는 메서드를 만들어주자.
소스코드
출처
728x90
'PS > Baekjoon Online Judge' 카테고리의 다른 글
[백준 11659] 구간 합 구하기 4 [Java] (0) | 2024.07.21 |
---|---|
[백준 11726] 2×n 타일링 [Python] (0) | 2024.07.21 |
[백준 01149] RGB거리 [C/C++] (2) | 2024.07.20 |
[백준 06322] 직각 삼각형의 두 변 [Python] (0) | 2024.07.20 |
[백준 13939] Imena [Java] (0) | 2024.07.18 |