반응형
문제
풀이
일반적인 두 포인터 문제다.
처음부터 마지막까지, 양동이의 양을 더하고 빼주면서 최대합을 구한다.
범위 계산이 귀찮았는데, 정확하게 계산해 범위 초과 이슈가 나지 않도록 유의한다.
소스 코드
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
#include <iostream>
#include <algorithm>
using namespace std;
const int MAX_COUNT = 1000001;
int ice[MAX_COUNT];
int main()
{
int N = 0;
int K = 0;
cin >> N >> K;
int maxIdx = 0;
while (N--)
{
int value = 0;
int idx = 0;
cin >> value >> idx;
ice[idx] = value;
if (idx > maxIdx)
maxIdx = idx;
}
int sum = 0;
for (int idx = 0; idx <= 2 * K; idx++)
{
if (idx >= MAX_COUNT)
break;
sum += ice[idx];
}
int result = sum;
int start = 0;
for (int end = 2 * K + 1; end <= maxIdx; end++)
{
sum += ice[end];
sum -= ice[start];
result = max(result, sum);
start++;
}
cout << result;
return 0;
}
|
cs |
반응형
'알고리즘 > 백준' 카테고리의 다른 글
[백준 2302] 극장 좌석 C++ (0) | 2023.05.11 |
---|---|
[백준 5972] 택배 배송 C++ (1) | 2023.03.03 |
[백준 2473] 세 용액 C++ (10) | 2023.02.20 |
[백준 2467] 용액 C++ (0) | 2023.02.19 |
[백준 1937] 욕심쟁이 판다 C++ (1) | 2023.02.11 |