두 개의 자연수를 입력받아 최대 공약수와 최소 공배수를 출력하는 프로그램을 작성하시오.
입력 : 첫째 줄에는 두 개의 자연수가 주어진다. 이 둘은 10,000이하의 자연수이며 사이에 한 칸의 공백이 주어진다.
출력 : 첫째 줄에는 입력으로 주어진 두 수의 최대공약수를, 둘째 줄에는 입력으로 주어진 두 수의 최소 공배수를 출력한다.
<풀이>
최대공약수를 먼저 구한다음에 두 수를 곱한값에다가 나누면 최소공배수가 된다. 런타임 에러가 어디서 났는 지 아직 못찾음. 해결해야 함.
import java.util.Scanner;
public class Q2609_max_min {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc= new Scanner(System.in);
int n1, n2, lcd=0, gcd=0;
n1=sc.nextInt();
n2=sc.nextInt();
for(int i=2; i<n1 && i<n2; i++)
if(n1%i==0 && n2%i==0)
gcd=i;
lcd=n1*n2/gcd;
System.out.println(gcd+"\n"+lcd);
}
}
'Study > Algorithm' 카테고리의 다른 글
[1026] 보물 (0) | 2020.05.22 |
---|---|
[1890] 점프 (0) | 2020.05.22 |
[3036] 링 (2) | 2020.05.13 |
[1932] 정수 삼각형 (0) | 2020.05.13 |
[14501] 퇴사 (0) | 2020.05.12 |
댓글