inblog logo
|
moohyun
    알고리즘문제풀기

    최댓값 만들기 (2)

    난이도 최하
    화낼거양's avatar
    화낼거양
    Feb 28, 2025
    최댓값 만들기 (2)
    Contents
    정답
     
    출처 : https://school.programmers.co.kr/learn/courses/30/lessons/120862?language=java
     

    문제 설명

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

    제한사항

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

    입출력 예

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

    입출력 예 설명

    입출력 예 #1
    • 두 수의 곱중 최댓값은 -3 * -5 = 15 입니다.
    입출력 예 #2
    • 두 수의 곱중 최댓값은 10 * 24 = 240 입니다.
    입출력 예 #3
    • 두 수의 곱중 최댓값은 20 * 30 = 600 입니다.
     
     

    정답

     
    import java.util.Arrays; class Solution { public int solution(int[] numbers) { Arrays.sort(numbers); int maxNum1 = numbers[numbers.length - 1]; int maxNum2 = numbers[numbers.length - 2]; int minNum1 = numbers[0]; int minNum2 = numbers[1]; return maxNum1 * maxNum2 < minNum1 * minNum2 ? minNum1 * minNum2 : maxNum1 * maxNum2; } }
     
    • 최대값 및 최소값 계산:
      • int maxNum1 = numbers[numbers.length - 1]; int maxNum2 = numbers[numbers.length - 2]; int minNum1 = numbers[0]; int minNum2 = numbers[1];
      • maxNum1 및 maxNum2: 정렬된 배열에서 가장 큰 두 숫자를 의미합니다.
      • minNum1 및 minNum2: 정렬된 배열에서 가장 작은 두 숫자를 의미합니다.
    • 최대 곱 계산:
      • return maxNum1 * maxNum2 > minNum1 * minNum2 ? maxNum1 * maxNum2 : minNum1 * minNum2; } }
      • 두 쌍의 곱을 비교합니다. maxNum1 * maxNum2(양수의 곱) 이minNum1 * minNum2(음수의 곱) 보다 크면 양수의 곱을 반환, 그렇지 않으면 음수의 곱을 반환합니다.
     
    Share article
    Contents
    정답

    moohyun

    RSS·Powered by Inblog