2020寒假【gmoj1967】【数列】【树状数组】

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

题目描述

给定一个长度为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
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值