洛谷P1714

P1714 切蛋糕

又是单调队列 /吐血

点击查看代码
#include<bits/stdc++.h>
using namespace std;

int main() {
    int n, m; cin >> n >> m;
    vector<int> a(n + 1), s(n + 1, 0);

    for(int i = 1; i <= n; i++) {
        cin >> a[i];
        s[i] = s[i - 1] + a[i];
    }
    int res = INT_MIN;
    deque<int> dq;
    dq.push_back(0);

    for(int i = 1; i <= n; i++) {
        while(!dq.empty() && dq.front() < i - m) dq.pop_front();

        res = max(res, s[i] - s[dq.front()]);

        while(!dq.empty() && s[dq.back()] >= s[i]) dq.pop_back();
        dq.push_back(i);
    }
    cout << res << '\n';
    return 0;
}

//比较每个长度为m的区间中最大子段和,能有部分分
// int main() {
//     int n, m; cin >> n >> m;
//     vector<int> p(n);
//     for(int i = 0; i < n; i++) cin >> p[i];
//     int nmax = 0;
//     for(int j = 0; j <= n - m; j++){
//         int ans = 0, tmp = -501;
//         for(int i = 0; i < m; i++) {
//             tmp = max(tmp + p[i + j], p[i + j]);
//             ans = max(tmp, ans);
//         }
//         nmax = max(nmax, ans);
//     }
//     cout << nmax;
//     return 0;
// }
posted @ 2025-05-14 15:43  Chuan81  阅读(3)  评论(0)    收藏  举报