萌新求助——看不懂正解代码
  • 板块学术版
  • 楼主bwzhw
  • 当前回复4
  • 已保存回复4
  • 发布时间2021/11/26 08:26
  • 上次更新2023/11/3 23:34:08
查看原帖
萌新求助——看不懂正解代码
582179
bwzhw楼主2021/11/26 08:26

#include <bits/stdc++.h>
using namespace std;
const int N = 1000005;
typedef long long LL;
int a[N], n, sum[N], k, h;
LL ans, f[N], g[N];
int main() {
    scanf("%d%d", &n, &k);
    for (int i = 1; i <= n; ++i) {
        scanf("%d", &a[i]);
        sum[i] = sum[i - 1] + a[i];
        f[i] = 1;
    }
    h = 0;

    for (int i = 1; i <= n; ++i) {
        while (h <= n && sum[h] - sum[i - 1] <= k) ++h;
        ans += f[i] * (n - i + 1);
        f[h] += f[i];
    }
    cout << ans;
}
2021/11/26 08:26
加载中...