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

 

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

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

programmers.co.kr

 

 

문제 분석

- 두 배열의 값을 뽑아 곱한 수를 더한 최솟값을 만들기 위해 가장 작은 값X가장 큰 값을 곱하면 된다.

 

 

문제 풀이

1. 각 배열 A, B를 작은 수부터 정렬한다.

2. for문을 통해서 A배열의 가장 작은 값과 B배열의 가장 큰 값을 곱한 값을 정답에 누적하여 더한다.

3. 정답을 반환한다.

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[B.length-i-1];
        }

        return answer;
    }
}

 

 

https://github.com/SOEUN2/Algorithm

'Algorithm > programmers' 카테고리의 다른 글

programmers 숫자의 표현  (0) 2022.05.04
programmers 최댓값과 최솟값  (1) 2022.05.03
programmers 피보나치 수  (0) 2022.05.01
programmers 행렬의 곱셈  (0) 2022.05.01
programmers JadenCase 문자열 만들기  (0) 2022.04.18