Contents

최댓값 만들기 2 (with.Java)

   Apr 30, 2024     1 min read

“최댓값 만들기 2 (with.Java)” 문제에 대하여 알아본 글입니다.

코딩 테스트 문제를 풀며, 풀었던 문제에 대한 회고와 다른 풀이 방법을 알아보며, 알아가고자 합니다.

문제에 대해 먼저 알아보겠습니다.

문제

정수 배열 numbers가 매개변수로 주어집니다.

numbers의 원소 중 두 개를 곱해 만들 수 있는 최댓값을 return하도록 solution 함수를 완성해주세요.

제한사항

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

입출력 예시

numbersresult
[1, 2, -3, 4, -5]15
[0, -31, 24, 10, 1, 9]240
[10, 20, 30, 5, 5, 20, 5]600

문제에 대한 나의 풀이

import java.util.Arrays;

class Solution {
    public int solution(int[] numbers) {
        Arrays.sort(numbers);

        int n = numbers.length;
        int maxNegative = numbers[0] * numbers[1];
        int maxPositive = numbers[n - 1] * numbers[n - 2];

        return Math.max(maxNegative, maxPositive);
    }
}

풀이 설명

  • 배열 정렬: 주어진 배열을 정렬하여 음수와 양수를 구분합니다.
  • 음수 중 가장 큰 두 수 선택: 정렬된 배열의 첫 번째와 두 번째 요소를 선택하여 음수 중 가장 큰 두 수를 곱한 값을 계산합니다.
  • 양수 중 가장 큰 두 수 선택: 정렬된 배열의 마지막과 마지막에서 두 번째 요소를 선택하여 양수 중 가장 큰 두 수를 곱한 값을 계산합니다.
  • 결과 반환: 음수와 양수를 곱한 값 중 더 큰 값을 반환합니다.

코드 장점

  • 간단한 로직: 배열을 정렬하고 가장 큰 수와 두 번째로 큰 수를 선택하여 곱하는 간단한 방법을 사용했습니다.
  • 정렬을 통한 효율성: 정렬된 배열을 사용하여 가장 큰 수를 선택하는 과정을 빠르고 간단하게 구현했습니다.

코드 단점

  • 배열 정렬로 인한 시간 복잡도: 배열을 정렬하는 과정에 대한 시간 복잡도가 O(n log n)으로, 배열이 큰 경우 성능에 영향을 줄 수 있습니다.