Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 잔
- HTML #CSS
- BOJ #컴퓨터공학 #C++ #알고리즘 #자료구조
- 컴퓨터공학 #자료구조 #스택 #c++ #알고리즘 #백준문제풀이
- 컴퓨터공학 #c #c언어 #문자열입력
- 컴퓨터공학 #Java #자바 #클래스 #객체 #인스턴스
Archives
- Today
- Total
영벨롭 개발 일지
[백준 BOJ][C++]11399번 ATM 풀이: 그리디 알고리즘 본문
https://www.acmicpc.net/problem/11399
각 사람이 돈을 인출하는데 필요한 시간의 합이 최소가 되려면 시간이 적게 걸리는 사람일수록 앞에 서야합니다.
입력으로 들어온 시간 Pi를 오름차순으로 정렬한 뒤, 각 시간을 점차 더해주면 됩니다.
시간 Pi의 자료구조로 배열을 사용해도 되지만, 정렬하기 귀찮으니 저는 우선순위큐를 사용했습니다.
C++ 컨테이너인 priority_queue를 사용하여 push와 동시에 오름차순으로 정렬되게 하였습니다.
#include<iostream>
#include<queue>
#include<algorithm>
using namespace std;
int main(void) {
int n;
priority_queue<int, vector<int>, greater<int>> p; //시간 우선순위큐
cin >> n;
for (int i = 0; i < n; i++) {
int temp;
cin >> temp;
p.push(temp);
}
int prev;
int result;
prev = result = p.top();
p.pop();
while (!p.empty()) {
prev = prev + p.top(); //i번째 사람 시간=앞 사람 시간+i번째 사람이 인출하는데 걸리는 시간
result += prev;
p.pop();
}
cout << result;
return 0;
}
반응형
'알고리즘 문제 풀이 > BOJ' 카테고리의 다른 글
[백준 BOJ][C++]11052번 카드 구매하기: DP (0) | 2022.02.25 |
---|---|
[백준 BOJ][C++]11047번 동전 0 풀이: 그리디 알고리즘 (0) | 2022.02.24 |
[백준 BOJ][C++]9095번 1, 2, 3 더하기 풀이: DP (0) | 2022.02.24 |
[백준 BOJ][C++]1463번 1로 만들기: DP (0) | 2022.02.24 |
[백준 BOJ][C++]2004번: 조합 0의 개수 풀이 (0) | 2022.02.22 |