백준 알고리즘
[Bronze III] 배수와 약수 - 5086
성능 요약
메모리: 13152 KB, 시간: 4 ms
분류
수학, 사칙연산
문제 설명
4 × 3 = 12이다.
이 식을 통해 다음과 같은 사실을 알 수 있다.
3은 12의 약수이고, 12는 3의 배수이다.
4도 12의 약수이고, 12는 4의 배수이다.
두 수가 주어졌을 때, 다음 3가지 중 어떤 관계인지 구하는 프로그램을 작성하시오.
- 첫 번째 숫자가 두 번째 숫자의 약수이다.
- 첫 번째 숫자가 두 번째 숫자의 배수이다.
- 첫 번째 숫자가 두 번째 숫자의 약수와 배수 모두 아니다.
입력
입력은 여러 테스트 케이스로 이루어져 있다. 각 테스트 케이스는 10,000이 넘지않는 두 자연수로 이루어져 있다. 마지막 줄에는 0이 2개 주어진다. 두 수가 같은 경우는 없다.
출력
각 테스트 케이스마다 첫 번째 숫자가 두 번째 숫자의 약수라면 factor를, 배수라면 multiple을, 둘 다 아니라면 neither를 출력한다.
Code
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
32
use std::io;
fn main(){
loop{
let mut input_a = String::new();
io::stdin().read_line(&mut input_a).unwrap();
let v:Vec<i32>= input_a.split_whitespace().map(|x|->i32{x.parse().unwrap()}).collect();
if v[0]==0||v[1]==0{
break;
}else if v[0] <= v[1]{
if v[1]%v[0]==0 {
println!("factor");
}else{
println!("neither");
}
}else if v[0]>v[1]{
if v[0]%v[1]==0 {
println!("multiple");
}else{
println!("neither");
}
}
}
}