[ 다먹살 ]/- Coding

[백준] 1026 보물

엉망으로살기 2022. 1. 11. 09:50
반응형

https://www.acmicpc.net/problem/1026

 

1026번: 보물

첫째 줄에 N이 주어진다. 둘째 줄에는 A에 있는 N개의 수가 순서대로 주어지고, 셋째 줄에는 B에 있는 수가 순서대로 주어진다. N은 50보다 작거나 같은 자연수이고, A와 B의 각 원소는 100보다 작거

www.acmicpc.net

 

문제 자체에 재배열할 수 있는 집합에 대한 제한조건이 있어 어려운 것처럼 보이지만 결국 정렬을 활용하는 문제이다. 배열, 리스트, 우선순위 큐 등 어떤 것을 사용해도 결국 Arrays.sort나 Collections.sort를 활용하면 해결할 수 있는 문제였다.


문제 및 입출력


예제


코드

import java.util.Scanner;
import java.util.Arrays;

public class Main
{
    public static void main(String[] args)
    {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int sum = 0;
        int[] arr1 = new int[n];
        int[] arr2 = new int[n];
                
        for(int i=0; i<n; i++)
        {
            arr1[i] = sc.nextInt();
        }
        for(int i=0; i<n; i++)
        {
            arr2[i] = sc.nextInt();
        }
        
        Arrays.sort(arr1);
        Arrays.sort(arr2);
                
        for(int i=0; i<n; i++)
        {
            sum += arr1[i]*arr2[n-1-i];
        }
        
        System.out.println(sum);
        sc.close();
    }
}

 

반응형