import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
int N = Integer.parseInt(st.nextToken());
int M = Integer.parseInt(st.nextToken());
int gcd = gcd(N, M);
System.out.println(gcd);;
int new2 = N*M/gcd;
System.out.println(new2);
}
public static int gcd(int n, int m)
{
while(m!=0)
{
int temp = m;
m= n % m;
n = temp;
}
return n;
}
}
오랜만에 최대공약수,최소공배수를 구하는 문제였다. gcd메서드를 까먹어서 이전에 쓴 벨로그를 참고하여 풀었다. 최대 공약수는 gdc,temp,%만 기억하면 될 것 같다.