일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- 프로그래머스
- VIM
- Database
- 알고리즘
- 안드로이드
- frontend
- git
- DFS
- java
- LeetCode
- Javascript
- 백준
- DP
- 다이나믹 프로그래밍
- Graph
- 동적 계획법
- 그레이들
- Redux
- Algorithm
- db
- Python
- CS
- network
- BFS
- 리트코드
- vscode
- react
- Data Structure
- TypeScript
- 자바
Archives
- Today
- Total
늘 겸손하게
문제 11399 ( Java ) - ATM 문제 본문
ATM 문제
그리디 알고리즘으로 푸는 문제이다.
그리디 알고리즘을 정의를 다시 생각해보자. 현 상황에서 최적의 선택을 하는 과정을 정답이 나올때까지 반복하는알고
리즘이 그리디 알고리즘이다. 이 알고리즘을 문제에 적용해보자.
문제를 보면 N 명의 사람이 있고, 각 사람이 돈을 인출하는데 걸리는 시간이 Pi 라고 한다. 이 문제에 그리디 알고리즘을
적용하면 현재 가장 돈을 인출하는데 걸리는 시간이 적은 사람을 선택하고, 선택한 사람을 제외한 사람들중에서 가장 돈
을 인출하는데 걸리는 시간이 적은 사람을 선택하는 과정을 N번 반복하면 된다.
이를 코드로 구현하기 위해서는 N개의 Pi를 배열에 저장하고, 배열을 오름차순으로 정렬시킨 다음 적은 숫자부터 선형으
로 골라주면 된다.
코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
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 [] arr = new int[N];
for ( int i = 0; i < N ; i++ ) {
arr[i] = sc.nextInt();
}
Arrays.sort(arr);
int sum = 0;
int sum2 = 0;
for ( int Pi : arr ) {
sum += Pi;
sum2 += sum;
}
System.out.print(sum2);
}
}
|
cs |
결과
'코딩 문제 > 백준' 카테고리의 다른 글
문제 9375 (Java) - 정수, 조합론 문제 (0) | 2021.07.10 |
---|---|
문제 1541 ( Java ) - 잃어버린 괄호 (0) | 2021.07.04 |
문제 1931 ( C++) (0) | 2021.07.03 |
문제 11047 ( C++ ) (0) | 2021.07.02 |
문제 15649 ( C++ ) (0) | 2021.06.29 |