[백준/BOJ] 5086번_배수와 약수 (C++/Java)

JIMIN·2023년 1월 27일

BOJ_Bronze

목록 보기
21/75

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

문제


4 × 3 = 12이다.

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

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

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

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

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

입력


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


출력


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



💻 예제 입력

8 16
32 4
17 5
0 0

💻 예제 출력

factor
multiple
neithern

C++ 소스코드


#include <iostream>
using namespace std;

int main(void)
{
    int a, b;
    while (1)
    {
        cin >> a >> b;
        if (!(a && b))
            return 0;
        
        // 배수라면?
        if (a % b == 0)
            cout << "multiple\n";
        
        // 약수라면?
        else if (b % a == 0)
            cout << "factor\n";
        
        else
            cout << "neither\n";
    }
}

Java 소스코드


import java.util.Scanner;

public class Main {
    public static void main(String[] args)
    {
        Scanner sc = new Scanner(System.in);
        int a, b;

        while (true) {
            a = sc.nextInt();
            b = sc.nextInt();

            if (a == 0 && b == 0)
                return;

            // 배수라면?
            if (a % b == 0)
                System.out.println("multiple");

            // 약수라면?
            else if (b % a == 0)
                System.out.println("factor");

            else
                System.out.println("neither");
        }
    }
}
profile
잘못된 코드나 정보가 있다면 알려주세요! 👋🏻

0개의 댓글