본문 바로가기

컴퓨터 프로그래밍/알고리즘

프로그래머스-최솟값 만들기

https://programmers.co.kr/learn/courses/30/lessons/12941?language=java

 

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

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

programmers.co.kr

<내풀이>

각각의 배열의 가장 작은 수와 가장 큰수를 차례로 곱해서 더해줍니다. 

package algorithm_2;

import java.util.ArrayList;

public class l5 {
	  public static int solution(int []A, int []B) {
		 int answer = 0;
		 
		 ArrayList<Integer> AArray = new ArrayList<>();
		 ArrayList<Integer> BArray = new ArrayList<>();
		 
		 for(int i=0; i<A.length;i++) {
			 AArray.add(A[i]);
			 BArray.add(B[i]);	 
		 }
		 AArray.sort(null);
		 BArray.sort(null);
		 
		 for(int j=0;j<AArray.size();j++) {
			 answer+=AArray.get(j)*BArray.get(AArray.size()-1-j);	 
		 }  
	        // [실행] 버튼을 누르면 출력 값을 볼 수 있습니다.
	        System.out.println("Hello Java");

	        return answer;
	}

	public static void main(String[] args) {
		int[] A= {1, 4, 2};
		int[] B= {5, 4, 4};
		int[] C= {1, 2};
		int[] D= {3, 4};	
		
		System.out.println(solution(C, D));
		
	}
}