151412025-02-13 16:40:28PKBVásárlás (75 pont)cpp17Accepted 75/7561ms2040 KiB
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int main(){

    int N;
    cin >> N;

    vector<long long> A(N), B(N);
    for (int i = 0; i < N; i++){
        cin >> A[i];
    }
    long long baseCost = 0;
    for (int i = 0; i < N; i++){
        cin >> B[i];
        baseCost += B[i];
    }

    // d[i] = a[i] - b[i]
    long long currentMin = 0, bestMin = 0;
    for (int i = 0; i < N; i++){
        long long d = A[i] - B[i];
        currentMin = min(0LL, currentMin + d);
        bestMin = min(bestMin, currentMin);
    }

    long long result = baseCost + bestMin;
    cout << result << "\n";

    return 0;
}
SubtaskSumTestVerdictTimeMemory
base75/75
1Accepted0/01ms316 KiB
2Accepted0/029ms1076 KiB
3Accepted3/31ms316 KiB
4Accepted4/41ms316 KiB
5Accepted4/41ms316 KiB
6Accepted4/41ms316 KiB
7Accepted4/42ms396 KiB
8Accepted3/32ms316 KiB
9Accepted4/42ms316 KiB
10Accepted4/42ms316 KiB
11Accepted4/42ms428 KiB
12Accepted5/52ms316 KiB
13Accepted3/357ms1984 KiB
14Accepted3/359ms1976 KiB
15Accepted3/359ms1976 KiB
16Accepted3/359ms1980 KiB
17Accepted3/359ms1844 KiB
18Accepted3/359ms2040 KiB
19Accepted3/357ms1980 KiB
20Accepted3/359ms1976 KiB
21Accepted3/361ms1988 KiB
22Accepted3/339ms1980 KiB
23Accepted3/361ms1984 KiB
24Accepted3/357ms1844 KiB