题目描述
给定一个长度为N的数列,求一段连续的子数列满足该子数列中的各元素的平均数大于A,输出可行方案的总数。
输入
第一行两个整数N,A
接下来N个整数,代表数列的N个元素。
输出
一个整数,即可行的方案数。
样例输入
5 1
1 2 3 4 5
样例输出
14
hint
对于60%的数据 N <= 1000
对于100%的数据 N <= 100000
所有数据包括都在longint范围内。
分析
一眼看去像是一道水题。仔细一看60分肯定没问题,100分好像有点难度。
60分代码就不放了,100分要用到树状数组,放了个友链,不会可以去学习一哈。
利用树状数组的前缀和,位运算,区间和,维护等操作,这题就可以搞定了!
上代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
long long n,m,a[100010],t,ans,f[100010],p;//long long
struct node
{
//结构体存位置与前缀和
long long sum,place;
}b[100010

本文介绍了一种使用树状数组优化求解子序列平均数问题的方法,通过两次排序和树状数组的操作,实现了对子序列平均数大于特定值的方案数的高效计算。
最低0.47元/天 解锁文章
457

被折叠的 条评论
为什么被折叠?



