정수 배열 numbers
가 매개변수로 주어집니다. numbers
의 원소 중 두 개를 곱해 만들 수 있는 최댓값을 return하도록 solution 함수를 완성해주세요.
numbers
의 원소 ≤ 10,000numbers
의 길이 ≤ 100numbers | result |
---|---|
[1, 2, -3, 4, -5] | 15 |
[0, -31, 24, 10, 1, 9] | 240 |
[10, 20, 30, 5, 5, 20, 5] | 600 |
입출력 예 #1
입출력 예 #2
입출력 예 #3
const solution = (numbers) => {
const sort = numbers.sort((a, b) => a - b);
return sort[0] * sort[1] > sort[sort.length-1] * sort[sort.length-2] ?
sort[0] * sort[1] : sort[sort.length-1] * sort[sort.length-2];
}
/*
const sort = numbers.sort((a, b) => a - b): 주어진 배열 numbers를 오름차순으로
정렬하여 새로운 배열 sort에 할당한다. 정렬된 배열을 사용하는 이유는 최댓값을 찾기 위해 가장 큰 두 개의
숫자를 선택하기 위해서다.
2. return sort[0] * sort[1] > sort[sort.length-1] * sort[sort.length-2] ?
sort[0] * sort[1] : sort[sort.length-1] * sort[sort.length-2]:
정렬된 배열에서 가장 작은 두 개의 숫자(sort[0], sort[1])와
가장 큰 두 개의 숫자(sort[length-1], sort[length-2])를 곱한 결과 중 최댓값을 반환한다.
삼항 연산자를 사용하여 비교하고, 만약 작은 두 수의 곱이 큰 두 수의 곱보다 크다면
작은 두 수의 곱을 반환하고, 그렇지 않으면 큰 두 수의 곱을 반환한다.
*/
function solution(numbers) {
numbers.sort((a, b) => a - b);
return Math.max(numbers[0]*numbers[1],
numbers[numbers.length-1]*numbers[numbers.length-2]);
}
/*
다른 분의 코드를 보고 삼항연산자를 사용안하고 Math.max를 이용해서 최댓값을 구하는 방법을 알게되어
공부할겸 가져와 봤다.
1. numbers.sort((a, b) => a - b): 주어진 배열 numbers를 오름차순으로 정렬한다.
정렬된 배열을 사용하는 이유는 최댓값을 찾기 위해 가장 큰 두 개의 숫자를 선택하기 위해서다.
2. return Math.max(numbers[0]*numbers[1],
numbers[numbers.length-1]*numbers[numbers.length-2]):
이 부분은 정렬된 배열에서 가장 작은 두 개의 숫자(numbers[0], numbers[1])와
가장 큰 두 개의 숫자(numbers[length-1], numbers[length-2])를 곱한 결과 중 최댓값을 반환한다.
Math.max() 함수는 인자로 받은 값들 중에서 가장 큰 값을 반환한다.
여기서는 작은 두 수의 곱과 큰 두 수의 곱 중에서 가장 큰 값을 반환하게 된다.
*/
const solution = (numbers) => {
const length = numbers.length;
numbers.sort((a,b) => a - b);
return Math.max(
numbers[length-1] * numbers[length-2],
numbers[0] * numbers[1]
)
}
/* SOLUTION1과 SOLUTION2에서 numbers.length가 동일하게 계속 반복되고있다.
이 반복을 없애기 위해 length 변수를 만들어주어 사용했다. */