https://www.acmicpc.net/problem/1026
옛날 옛적에 수학이 항상 큰 골칫거리였던 나라가 있었다. 이 나라의 국왕 김지민은 다음과 같은 문제를 내고 큰 상금을 걸었다.
길이가 N인 정수 배열 A와 B가 있다. 다음과 같이 함수 S를 정의하자.
S = A[0] × B[0] + ... + A[N-1] × B[N-1]
S의 값을 가장 작게 만들기 위해 A의 수를 재배열하자. 단, B에 있는 수는 재배열하면 안 된다.
S의 최솟값을 출력하는 프로그램을 작성하시오.
첫째 줄에 S의 최솟값을 출력한다.
예제 1 입력
5
1 1 1 6 0
2 7 8 3 1예제 1 출력
18
예제 2 입력
3
1 1 3
10 30 20예제 2 출력
80
예제 3 입력
9
5 15 100 31 39 0 0 3 26
11 12 13 2 3 4 5 9 1예제 3 출력
528
const fs = require('fs');
const root = process.platform === 'linux' ? '/dev/stdin' : './input.txt';
const [[a], Arr1, Arr2] = fs.readFileSync(root, 'utf8').toString().trim().split('\n').map(a=> a.split(' ').map(a=>+a));
console.log(solution(a, Arr1, Arr2));
function solution(a, Arr1, Arr2) {
let temp1 = 0;
let temp2 = 0;
Arr1.sort((a,b)=> a-b);
Arr2.sort((a,b)=> b-a);
for(let i = 0; i < a; i++ ){
temp1 += Arr1[i] * Arr2[i]
}
Arr1.sort((a,b)=> b-a);
Arr2.sort((a,b)=> a-b);
for(let i = 0; i < a; i++ ){
temp2 += Arr1[i] * Arr2[i]
}
return temp1 >= temp2 ? temp2 : temp1 ;
};