문제
두 개의 자연수를 입력받아 최대 공약수와 최소 공배수를 출력하는 프로그램을 작성하시오.
입력
첫째 줄에는 두 개의 자연수가 주어진다. 이 둘은 10,000이하의 자연수이며 사이에 한 칸의 공백이 주어진다.
출력
첫째 줄에는 입력으로 주어진 두 수의 최대공약수를, 둘째 줄에는 입력으로 주어진 두 수의 최소 공배수를 출력한다.
제출
import java.util.*;
public class Q_2609 {
static int gcd(int a, int b) {
if(b == 0) return a;
return gcd(b, a % b);
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int a = sc.nextInt();
int b = sc.nextInt();
System.out.println(gcd(a,b));
System.out.println(a * b / gcd(a,b));
}
}
'코딩테스트 > JAVA 문제' 카테고리의 다른 글
[백준 - JAVA] 6588번 : 골드바흐의 추측 (0) | 2021.08.27 |
---|---|
[백준 - JAVA] 1978번 : 소수 찾기 (0) | 2021.08.25 |
[백준 - JAVA] 9613번 : GCD 합 (0) | 2021.08.25 |
[백준 - JAVA] 1934번 : 최소공배수 (0) | 2021.08.24 |
[백준 - JAVA] 10430번 : 나머지 (0) | 2021.08.24 |