알고리즘/미분류
[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가지 중 어떤 관계인지 구하는 프로그램을 작성하시오.
- 첫 번째 숫자가 두 번째 숫자의 약수이다.
- 첫 번째 숫자가 두 번째 숫자의 배수이다.
- 첫 번째 숫자가 두 번째 숫자의 약수와 배수 모두 아니다.
입력
입력은 여러 테스트 케이스로 이루어져 있다. 각 테스트 케이스는 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인것만 확인해서 틀렸다..
문제이해를 잘못한 것이다.