일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
Tags
- fragment에서 context사용
- RecyclerView
- Alert Dialog
- RETROFIT
- naver open api
- silver4
- 녹음기
- gradle설정
- map
- LV1
- 백준
- bronze2
- bronze3
- silver3
- 뷰클래스
- 다크모드제한
- Kotlin
- Android
- 프로그래머스
- LIS
- toLong()
- 테마변경
- stack
- Silver5
- dp
- recyclerView 클릭이벤트
- 임시저장하기
- bottom-up
- bronze4
- Top-Down
Archives
- Today
- Total
유니 코드
[BOJ/백준][Bronze III] 5086: 배수와 약수 (Kotlin) 본문
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인것만 확인해서 틀렸다..
문제이해를 잘못한 것이다.
'알고리즘 > 미분류' 카테고리의 다른 글
[BOJ/백준][Bronze II] 2577: 숫자의 개수 (Kotlin) (0) | 2022.02.25 |
---|---|
[BOJ/백준][Bronze III] 1085: 직사각형에서 탈출 (Kotlin) (0) | 2022.02.24 |
[BOJ/백준][Bronze III] 10872: 팩토리얼 (Kotlin) (0) | 2022.02.17 |
[BOJ/백준][Bronze IV] 10797: 10부제 (Kotlin) (0) | 2022.02.16 |
Comments