문제설명
두 수를 입력받아 두 수의 최대공약수와 최소공배수를 반환하는 함수, solution을 완성해 보세요. 배열의 맨 앞에 최대공약수, 그다음 최소공배수를 넣어 반환하면 됩니다.
function solution(n, m) {
function max(n,m){
// n에서 m을 나눈 나머지가 0 이면 m이 return 된다.
// n에서 m을 나눴을때 0이 나온다는 말은 n이 m의 배수라는 말이기때문에
// m이 최대 공약수가 된다고 할수 있다.
// n에서 m을 나눴을때 0이외의 값이 나오게 되면 재귀함수를 사용해서 구해준다
// 이 부분은 스터디 같이 하시는 분이 설명해주신 부분인데 이해는 되는데 혼자 구현하라고 하면 못할것같긴하다.
return n % m ? max(m, n%m) : m;
}
const maxNum = max(n,m);
// 최소공배수는 n과m을 곱한 값에 최대 공약수로 나눠주면 된다.
// 그 반대의 경우도 성립한다.
const minNum = n*m / maxNum;
return [maxNum, minNum];
}