[프로그래머스] 39. 9로 나눈 나머지

최재원's avatar
Mar 31, 2025
[프로그래머스] 39. 9로 나눈 나머지
💡

문제 설명

음이 아닌 정수를 9로 나눈 나머지는 그 정수의 각 자리 숫자의 합을 9로 나눈 나머지와 같은 것이 알려져 있습니다.
이 사실을 이용하여 음이 아닌 정수가 문자열 number로 주어질 때, 이 정수를 9로 나눈 나머지를 return 하는 solution 함수를 작성해주세요.
💡

제한사항

  • 1 ≤ number의 길이 ≤ 100,000
  • number의 원소는 숫자로만 이루어져 있습니다.
  • number는 정수 0이 아니라면 숫자 '0'으로 시작하지 않습니다.

입출력 예

number
result
"123"
6
"78720646226947352489"
2

입출력 예 설명

입출력 예 #1
  • 예제 1번의 number는 123으로 각 자리 숫자의 합은 6입니다. 6을 9로 나눈 나머지는 6이고, 실제로 123 = 9 × 13 + 6입니다. 따라서 6을 return 합니다.
입출력 예 #2
  • 예제 2번의 number는 78720646226947352489으로 각자리 숫자의 합은 101입니다. 101을 9로 나눈 나머지는 2이고, 실제로 78720646226947352489 = 9 × 8746738469660816943 + 2입니다. 따라서 2를 return 합니다.
 

코드

import java.math.BigInteger; class Solution { public int solution(String number) { BigInteger num = new BigInteger(number); return num.mod(BigInteger.valueOf(9)).intValue(); } }
notion image

풀이

  • 자바에서 long타입은 19자리 숫자까지만 표현 가능하다
  • BigInteger는 무한대까지 표기 가능하다
  • 따라서 이 문제에선 BigInteger를 사용해야 한다
  • mod(BigInteger.valueOf(9))
    • BigInteger기본 연산자 %를 사용할 수 없으므로, mod() 메서드를 사용하여 나머지를 구한다
    • BigInteger.valueOf(9)9BigInteger 타입으로 변환하여 mod() 연산이 가능하게 한다
  • .intValue()
    • mod()의 결과는 BigInteger이므로, int로 변환해야 한다
    • .intValue()를 호출하면 BigIntegerint로 변환한다
 
Share article

jjack1