알고리즘/백준

[백준 10025] 게으른 백곰 C++

겜도리도리 2023. 2. 23. 21:07
반응형

문제

백준 10025 게으른 백곰 C++

 

10025번: 게으른 백곰

첫 줄에 정수 N과 K가 들어온다. 둘째 줄부터 N째 줄까지, 공백을 사이에 두고 각 양동이의 얼음의 양을 나타내는 gi와 양동이의 좌표를 나타내는 xi가 주어진다.

www.acmicpc.net

풀이

일반적인 두 포인터 문제다.

처음부터 마지막까지, 양동이의 양을 더하고 빼주면서 최대합을 구한다.

범위 계산이 귀찮았는데, 정확하게 계산해 범위 초과 이슈가 나지 않도록 유의한다.

소스 코드

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 + 1end <= 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