JAVA/Algorithm

[프로그래머스/java] 최솟값 만들기

nang. 2021. 1. 7. 20:58
반응형
SMALL

https://programmers.co.kr/learn/courses/30/lessons/12941

 

코딩테스트 연습 - 최솟값 만들기

길이가 같은 배열 A, B 두개가 있습니다. 각 배열은 자연수로 이루어져 있습니다. 배열 A, B에서 각각 한 개의 숫자를 뽑아 두 수를 곱합니다. 이러한 과정을 배열의 길이만큼 반복하며, 두 수를 곱

programmers.co.kr

 

 

  • 각 배열의 숫자 하나씩 뽑아서 곱한 후 다 더한 값이 최소가 되게 만들려면
    • 하나의 배열에서 제일 작은 값 + 하나의 배열에서 제일 큰 값 이어야 하므로
    • 각 배열을 하나는 오름차순, 하나는 내림차순 처리 해준 뒤 곱한다.

 

import java.util.*;

class Solution
{
    public int solution(int []A, int []B)
    {
        int answer = 0;

        Arrays.sort(A);
        Arrays.sort(B);
        
        for(int i = 0; i < A.length; i++) {
            answer += A[i] * B[A.length-i-1];
        }

        return answer;
    }
}
반응형
LIST