쉬운 프로그래밍

[알고리즘] 백준 11399 ATM - JAVA 본문

알고리즘/그리디

[알고리즘] 백준 11399 ATM - JAVA

쉬운형 2021. 2. 20. 15:51

www.acmicpc.net/problem/11399

 

11399번: ATM

첫째 줄에 사람의 수 N(1 ≤ N ≤ 1,000)이 주어진다. 둘째 줄에는 각 사람이 돈을 인출하는데 걸리는 시간 Pi가 주어진다. (1 ≤ Pi ≤ 1,000)

www.acmicpc.net

문제만 이해하면 크게 어려울 것 없는 문제다.

 

돈을 인출하는데 필요한 시간이 적은 사람부터 뽑아야 시간의 합의 최솟값을 구할 수 있다.

 

따라서 p 배열을 먼저 정렬한 후, 이전값을 통해 걸린 시간의 총합을 구한다.

 

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;

public class Main {

    static int n;
    static int[] p;
    static int[] sum;

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String s = br.readLine();
        n = Integer.parseInt(s);
        p = new int[n];
        sum = new int[n];
        s = br.readLine();
        StringTokenizer st = new StringTokenizer(s, " ");

        for (int i = 0; i < n; i++) {
            p[i] = Integer.parseInt(st.nextToken());
        }

        Arrays.sort(p);

        int prev = 0;
        int sum = 0;

        for (int i = 0; i < n; i++) {
            sum = sum + prev + p[i];
            prev = prev + p[i];
        }

        System.out.println(sum);
    }
}
Comments