알고리즘/미분류

[BOJ/백준][Bronze III] 5086: 배수와 약수 (Kotlin)

꼬물쥰 2022. 2. 21. 21:36

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

 

5086번: 배수와 약수

각 테스트 케이스마다 첫 번째 숫자가 두 번째 숫자의 약수라면 factor를, 배수라면 multiple을, 둘 다 아니라면 neither를 출력한다.

www.acmicpc.net

 

문제

4 × 3 = 12이다.

이 식을 통해 다음과 같은 사실을 알 수 있다.

3은 12의 약수이고, 12는 3의 배수이다.

4도 12의 약수이고, 12는 4의 배수이다.

두 수가 주어졌을 때, 다음 3가지 중 어떤 관계인지 구하는 프로그램을 작성하시오.

  1. 첫 번째 숫자가 두 번째 숫자의 약수이다.
  2. 첫 번째 숫자가 두 번째 숫자의 배수이다.
  3. 첫 번째 숫자가 두 번째 숫자의 약수와 배수 모두 아니다.

입력

입력은 여러 테스트 케이스로 이루어져 있다. 각 테스트 케이스는 10,000이 넘지않는 두 자연수로 이루어져 있다. 마지막 줄에는 0이 2개 주어진다. 두 수가 같은 경우는 없다.


출력

각 테스트 케이스마다 첫 번째 숫자가 두 번째 숫자의 약수라면 factor를, 배수라면 multiple을, 둘 다 아니라면 neither를 출력한다.


풀이

import java.util.*

fun main() {
     while(true){
        var input = readLine()!!.split(" ").map{it.toInt()}
        if(input[0] == 0 && input[1] == 0) break
        
        if(input[0] > input[1]){
            if(input[0] % input[1] ==0) {
                println("multiple")
            } else {
                println("neither")
            }
        } else{
            if(input[1] % input[0] ==0) {
                println("factor")
            } else {
                println("neither")
            }
        } 
    }
}

입력이 0 0일 때까지 무한루프를 이용하여 배수와 약수를 판별하였다.

%연산자를 이용해 나머지가 0인경우일 때,

첫 번째 숫자가 크다면 multiple 두번째 숫자가 크다면 factor를 출력한다.


내가 생각했던 풀이가 맞긴했다.

틀린 이유가 입력 받을 때 첫번째, 두번째 수 둘다 0일경우를 체크해야하는데

나는 첫번째 숫자가 0인것만 확인해서 틀렸다..

문제이해를 잘못한 것이다.