백준 5086 - 배수와 약수 [Rust]

[Bronze III] 배수와 약수 - 5086

Posted by Hebi on March 27, 2023

백준 알고리즘

[Bronze III] 배수와 약수 - 5086

문제 링크

성능 요약

메모리: 13152 KB, 시간: 4 ms

분류

수학, 사칙연산

문제 설명

4 × 3 = 12이다.

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

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

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

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

  1. 첫 번째 숫자가 두 번째 숫자의 약수이다.
  2. 첫 번째 숫자가 두 번째 숫자의 배수이다.
  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");
             }
    }

  }


}