[ 프로그래머스 ] : 최솟값 만들기
in Algorithm
https://school.programmers.co.kr/learn/courses/30/lessons/12941
길이가 같은 배열 A, B 두개가 있습니다. 각 배열은 자연수로 이루어져 있습니다. 배열 A, B에서 각각 한 개의 숫자를 뽑아 두 수를 곱합니다. 이러한 과정을 배열의 길이만큼 반복하며, 두 수를 곱한 값을 누적하여 더합니다. 이때 최종적으로 누적된 값이 최소가 되도록 만드는 것이 목표입니다. (단, 각 배열에서 k번째 숫자를 뽑았다면 다음에 k번째 숫자는 다시 뽑을 수 없습니다.)
CASE 1
function solution(A,B){
var answer = 0;
A.sort((a,b) => a-b)
B.sort((a,b) => b-a)
for(let i=0; i<A.length; i++){
answer += A[i] * B[i]
}
return answer;
}
문제를 풀다가 2중 for문의 i !== k
까지 갔는데 그렇게 하니까 너무 복잡해져서 중도에 포기한 문제.. 흑흑 ( •́દ•̩̥̀ )
그래서 다른 사람들 풀이를 봤는데…
아..sort를 여기서 사용해도 되는구나.. 생각이 들었고,
나는 도대체 왜 배열의 최솟값과 최댓값을 곱해야 ‘‘합의 최솟값’이 나온다는건지 처음에는 이해가 안됐음
최솟값이랑 최솟값이랑 곱해줘야 최소가 되는거 아니야? 라고 생각했는데..
그건 너무 짧은 시각이었다. ((●´∧`●))….
합의 최솟값을 구하기 위해서는 어찌되었든 최소의 수를 도출해내는게 중요한데,
만약 두 배열 모두 오름차순으로 정렬해버리면 처음에는 최솟값 * 최솟값으로 시작하겠지만
결국 배열의 끝에서는 최댓값 * 최댓값이 되어버리기 때문에 조금이라도 덜 크게 만드려면
최솟값 * 최댓값이어야지 합의 최솟값이 되는 것이다….! (큰 깨달음 ~(˘▾˘~))