문제 설명
정수 배열 numbers가 매개변수로 주어집니다. numbers의 원소 중 두 개를 곱해 만들 수 있는 최댓값을 return하도록 solution 함수를 완성해주세요.
제한 사항
- 0 ≤ numbers의 원소 ≤ 10,000
- 2 ≤ numbers의 길이 ≤ 100
입출력 예
나의 풀이
function solution(numbers) {
// numbers 배열의 최댓값 저장
const firstMaxNum = Math.max(...numbers);
// numbers 배열에서 첫번째 최댓값 제거
numbers.splice(numbers.indexOf(firstMaxNum), 1)
// 첫번째 최댓값 제거된 numbers 배열에서 두번째 최댓값 저장
const secondMaxNum = Math.max(...numbers);
return firstMaxNum * secondMaxNum;
}
다른 사람의 풀이
나의경우 첫번째 최댓값과 두번째 최대값을 직접 구하여 곱하려고 하였는데 다른 사람의 풀이를보면 내림차순 정렬을 통해 쉽게 풀 수 있었다.
function solution(numbers) {
numbers.sort((a,b)=>b-a);
return numbers[0]*numbers[1];
}
'programmers > level 0' 카테고리의 다른 글
Programmers - Js - 머쓱이보다 키 큰 사람 (0) | 2023.02.28 |
---|---|
Programmers - Js - 배열 두 배 만들기 (0) | 2023.02.28 |
Programmers - Js - 짝수 홀수 개수 (0) | 2023.02.27 |
Programmers - Js - 배열 원소의 길이 (0) | 2023.02.27 |
Programmers - Js - 피자 나눠 먹기(3) (0) | 2023.02.26 |