[코딩테스트] 프로그래머스 12941, 최솟값 만들기

2022. 5. 16. 18:49CodingTest

문제

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

 

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

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

programmers.co.kr

 

접근

  • 누적합을 최소로 만들기 위해서 배열 A,B를 모두 오름차순으로 정렬
  • 배열의 길이만큼 반복하면서 배열 A는 0번째부터, 배열 B는 n-i-1번째부터 내려가면서 누적합을 구함

코드

import java.util.Arrays;

public class Solution
{
    public int solution(int []A, int []B)
    {
        int answer = 0;
        int n = A.length;
        
        Arrays.sort(A);
        Arrays.sort(B);
        
        
        for(int i = 0; i < n; i++) {
        	answer += (A[i]*B[n-i-1]);
        }
        
        return answer;
    }
    
    public static void main(String[] args) {
    	int answer = new Solution().solution(new int[] {1, 4, 2}, new int[] {5, 4, 4});
    	System.out.println(answer);
    }
}