洛谷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;
// }