티스토리 뷰

Algorithm/BOJ

[C/C++] 백준 11399번 - ATM

poopooreum 2024. 3. 2. 09:37
반응형

✏️ 문제 링크

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

 

11399번: ATM

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

www.acmicpc.net

 

 

✏️ 문제 설명

 

✏️ 문제 풀이

 N이 1000이하이므로 O(n^2)의 삽입 정렬을 이용해도 무방 ※

인출 시간이 가장 적게 걸리는 사람이 가장 먼저 인출할 수 있도록 순서를 정하기(그리디 방식)

 

✏️ 문제 코드

#include<iostream>
#include<vector>
using namespace std;
int main() {

	ios::sync_with_stdio(false);
	cin.tie(NULL);
	cout.tie(NULL);

	int N;
	cin >> N;

	vector<int>A(N, 0);
	vector<int>S(N, 0);

	for (int i = 0; i < N; i++)
		cin >> A[i];

	for (int i = 1; i< N; i++) {
		int point = i;
		int value = A[i];
		
		for (int j = i - 1; j >= 0; j--) {
			if (A[i] > A[j]) {
				point = j + 1;
				break;
			}
			if (j == 0)
				point = 0;
		}
		for (int j = i; j > point; j--) {
			A[j] = A[j - 1];
		}
		A[point] = value;
	}

	S[0] = A[0];

	for (int i = 1; i < N; i++) {
		S[i] = S[i - 1] + A[i];
	}

	int sum = 0;

	for (int i = 0; i < N; i++)
		sum += S[i];

	cout << sum;
}
반응형

'Algorithm > BOJ' 카테고리의 다른 글

[C/C++] 백준 1517번 - 버블 소트  (0) 2024.03.02
[C/C++] 백준 28278번  (0) 2024.03.02
[C/C++] 백준 10799번 - 쇠막대기  (0) 2024.03.01
[C/C++] 백준 1377번 - 버블 소트  (0) 2024.02.29
[C/C++] 백준 11286번 - 절댓값 힙  (0) 2024.02.28
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/07   »
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 31
글 보관함