https://www.acmicpc.net/problem/11399
11399번: ATM
첫째 줄에 사람의 수 N(1 ≤ N ≤ 1,000)이 주어진다. 둘째 줄에는 각 사람이 돈을 인출하는데 걸리는 시간 Pi가 주어진다. (1 ≤ Pi ≤ 1,000)
www.acmicpc.net
👉 풀이
- 각 사람이 돈을 인출하는데 필요한 시간은 그 사람의 앞 사람들이 돈을 인출하는데 걸리는 시간의 누적합이다.
- 따라서 돈을 인출하는데 걸리는 시간이 적은 사람부터 돈을 인출하면, 각 사람이 돈을 인출하는데 필요한 시간의 합이 최소가 된다.
- 1 ~ N 번까지 사람을 돈을 인출하는데 걸리는 시간이 적은 사람부터 정렬
- 누적합을 계속 더해간다.
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;
// https://www.acmicpc.net/problem/11399
public class p11399 {
public static void main(String[] args) throws IOException{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int n = Integer.parseInt(br.readLine());
int[] times = new int[n];
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
for(int i = 0; i < n; i++){
times[i] = Integer.parseInt(st.nextToken());
}
Arrays.sort(times);
int result = 0;
int sum = 0;
for (int time : times){
sum += time;
result += sum;
}
System.out.println(result);
}
}
'알고리즘 문제풀이 > 자바' 카테고리의 다른 글
[프로그래머스-그리디] 구명보트 JAVA 자바 (0) | 2022.11.21 |
---|---|
[백준-그리디] 13305: 주유소 JAVA 자바 (0) | 2022.11.19 |
[백준 - 그리디] 1541: 잃어번린 괄호 JAVA 자바 (0) | 2022.11.19 |
[백준-그리디] 1931: 회의실 배정 JAVA 자바 (0) | 2022.11.18 |
[백준-그리디] 11047번: 동전0 (0) | 2022.11.18 |