프로그래머스 - 최댓값 만들기 (2)

이한결·2022년 12월 10일
0

프로그래머스

목록 보기
56/107
post-thumbnail

문제 설명

정수 배열 numbers가 매개변수로 주어집니다. numbers의 원소 중 두 개를 곱해 만들 수 있는 최댓값을 return하도록 solution 함수를 완성해주세요.

제한사항

● -10,000 ≤ numbers의 원소 ≤ 10,000
● 2 ≤ numbers 의 길이 ≤ 100

입출력 예

입출력 예 설명

입출력 예 #1

두 수의 곱중 최댓값은 -3 * -5 = 15 입니다.

입출력 예 #2

두 수의 곱중 최댓값은 10 * 24 = 240 입니다.

입출력 예 #3

두 수의 곱중 최댓값은 20 * 30 = 600 입니다.

나의 코드

function solution(numbers) {
    let copyarr = [...numbers];
        copyarr.sort((a, b) => b - a);
        const bigone = copyarr[0] * copyarr[copyarr.length - 1];
        const bigsecon =
          copyarr[copyarr.length - 1] * copyarr[copyarr.length - 2];
        const bigthir = copyarr[0] * copyarr[1];
        let bigArr = [bigone, bigsecon, bigthir].sort((a, b) => b - a);
        return bigArr[0];
}
  1. 배열을 내림차순으로 정렬한다.
  2. 큰수가 나올 수 있는 3가지 경우의 수를 계산한다.
  3. 3가지 수를 다시 배열에 담아 내림차순으로 정렬한다.
  4. 가장 큰 수를 반환한다.

P.S. 우연찮게 패턴을 발견하여 문제를 풀었다...

끝!

profile
평범한 삶을 위하여

0개의 댓글