BZOJ 2006 [NOI2010]超级钢琴 (堆+主席树)
让你求前$K$大的子序列和,$n\leq 5*10^{5}$
只想到了个$nlog^{2}n$的做法,似乎要被卡常就看题解了..
好神奇的操作啊,我傻了
我们把序列和拆成两个前缀和相减
对于一个左端点$x$,它可以取的范围是$[x+l,x+r]$,查出该范围内的第1大值,然后把左端点编号$x$,取的是第几大值$k$,以及答案这些信息封成结构体推进堆里
根据贪心的策略我们要取最大的,要维护一个关于答案的大根堆
每次都取出堆顶元素,在$x$对应范围内查找第$k+1$大值,再把信息重新推回堆里,如此重复K次即可
上述过程也可以用区间RMQ实现,结构体里记录能取的左右端点就行了,每次取堆顶元素以后都拆成两部分推回堆里,似乎RMQ的做法空间常数会小不少
#include <queue>
#include <cstdio>
#include <cstring>
#include <algorithm>
#define N1 500010
#define M1 N1*30
#define ll long long
using namespace std; template <typename _T> void read(_T &ret)
{
ret=; _T fh=; char c=getchar();
while(c<''||c>''){ if(c=='-') fh=-; c=getchar(); }
while(c>=''&&c<=''){ ret=ret*+c-''; c=getchar(); }
ret=ret*fh;
} struct SEG{
int ls[M1],rs[M1],sz[M1],root[N1],tot;
inline void pushup(int rt)
{
sz[rt]=sz[ls[rt]]+sz[rs[rt]];
}
void update(int x,int l,int r,int rt1,int &rt2,int w)
{
if(!rt2||rt2==rt1){ rt2=++tot; ls[rt2]=ls[rt1]; rs[rt2]=rs[rt1]; sz[rt2]=sz[rt1]; }
if(l==r){ sz[rt2]+=w; return; }
int mid=(l+r)>>;
if(x<=mid) update(x,l,mid,ls[rt1],ls[rt2],w);
else update(x,mid+,r,rs[rt1],rs[rt2],w);
pushup(rt2);
}
int find(int K,int l,int r,int rt1,int rt2)
{
if(l==r) return l;
int mid=(l+r)>>;
if(K<=sz[rs[rt2]]-sz[rs[rt1]]) return find(K,mid+,r,rs[rt1],rs[rt2]);
else return find(K-sz[rs[rt2]]+sz[rs[rt1]],l,mid,ls[rt1],ls[rt2]);
}
}s; int n,nn,K,L,R;
int a[N1],b[N1]; ll sa[N1],t[N1];
struct node{
int x,K;ll val;
node(int x,int K,ll val):x(x),K(K),val(val){} node(){}
friend bool operator < (const node &s1,const node &s2)
{
if(s1.val!=s2.val) return s1.val<s2.val;
if(s1.x!=s2.x) return s1.x<s2.x;
return s1.K<s2.K;
}
};
priority_queue<node>q; int main()
{
scanf("%d%d%d%d",&n,&K,&L,&R);
int i,j,l,r,x,y,k; t[]=;
for(i=;i<=n;i++) read(a[i]), sa[i]=sa[i-]+a[i], t[i+]=sa[i];
sort(t+,t+n+); nn=unique(t+,t+n+)-(t+);
for(i=;i<=n;i++)
{
b[i]=lower_bound(t+,t+nn+,sa[i])-t;
s.update(b[i],,nn,s.root[i-],s.root[i],);
}
node p;
for(i=;i<n;i++)
{
l=i+L; if(l>n) continue; r=min(i+R,n);
x=s.find(,,nn,s.root[l-],s.root[r]);
q.push(node(i,,t[x]-sa[i]));
}
ll ans=;
while(K--)
{
p=q.top(); q.pop(); ans+=p.val;
i=p.x, l=i+L, r=min(i+R,n); if(p.K==r-l+) continue;
x=s.find(p.K+,,nn,s.root[l-],s.root[r]);
q.push(node(i,p.K+,t[x]-sa[i]));
}
printf("%lld\n",ans);
return ;
}
BZOJ 2006 [NOI2010]超级钢琴 (堆+主席树)的更多相关文章
- Bzoj 2006: [NOI2010]超级钢琴 堆,ST表
2006: [NOI2010]超级钢琴 Time Limit: 20 Sec Memory Limit: 552 MBSubmit: 2222 Solved: 1082[Submit][Statu ...
- BZOJ2006[NOI2010]超级钢琴——堆+主席树
题目描述 小Z是一个小有名气的钢琴家,最近C博士送给了小Z一架超级钢琴,小Z希望能够用这架钢琴创作出世界上最美妙的 音乐. 这架超级钢琴可以弹奏出n个音符,编号为1至n.第i个音符的美妙度为Ai,其中 ...
- BZOJ 2006: [NOI2010]超级钢琴( RMQ + 堆 )
取最大的K个, 用堆和RMQ来加速... ----------------------------------------------------------------- #include<c ...
- BZOJ 2006: [NOI2010]超级钢琴
2006: [NOI2010]超级钢琴 Time Limit: 20 Sec Memory Limit: 552 MBSubmit: 2613 Solved: 1297[Submit][Statu ...
- BZOJ 2006: [NOI2010]超级钢琴 [ST表+堆 | 主席树]
题意: 一个序列,求k个不相同的长度属于\([L,R]\)的区间使得和最大 前缀和,对于每个r找最小的a[l] 然后我yy了一个可持久化线段树做法...也许会T 实际上主席树就可以了,区间k小值 然后 ...
- BZOJ 2006 超级钢琴(堆+主席树)
很好的一道题. 题意:给出长度为n的数列,选择k个互不相同的区间,满足每个区间长度在[L,R]内,求所有选择的区间和的总和最大是多少.(n,k<=5e5). 首先将区间和转化为前缀和之差,那么我 ...
- BZOJ 2006: [NOI2010]超级钢琴 ST表+堆
开始想到了一个二分+主席树的 $O(n\log^2 n)$ 的做法. 能过,但是太无脑了. 看了一下题解,有一个 ST 表+堆的优美解法. 你发现肯定是选取前 k 大最优. 然后第一次选的话直接选固定 ...
- 洛谷 P2048 BZOJ 2006 [NOI2010]超级钢琴
题目描述 小Z是一个小有名气的钢琴家,最近C博士送给了小Z一架超级钢琴,小Z希望能够用这架钢琴创作出世界上最美妙的音乐. 这架超级钢琴可以弹奏出n个音符,编号为1至n.第i个音符的美妙度为Ai,其中A ...
- luogu2048 [NOI2010]超级钢琴 (优先队列+主席树)
思路:先扫一遍所有点作为右端点的情况,把它们能产生的最大值加到一个优先队列里,然后每次从优先队列里取出最大值,再把它对应的区间的次大值加到优先队列里,这样做K次 可以用一个前缀和,每次找i为右端点的第 ...
随机推荐
- org.hibernate.PropertyValueException: not-null property references a null or transient value: model.
今天在写一个SSH整合的项目时,首先将数据库操作部分单独分离出来,写完后使用Junit进行測试,经过測试.发现没有不论什么问题,对数据库中的内容进行增删改查没有问题,可是将他整合到SSH的项目中时,报 ...
- string 和 vector 初探
标准库类型 string string 表示可变长的字符序列.是C++标准库类型的一部分,拥有很多优秀的性能. 定义 string 对象时如未人为初始化编译器会默认初始化为空字符串. string 对 ...
- UVa 10693 - Traffic Volume
題目:車速為v,車之間的距離最少為v^2/(2f)(防止裝車),車長為L,問1小時最多能走過幾輛車. 分析:數學.物理. 根據題意能够列出方程:nL + (n-1)d = nL ...
- Extjs4,form提交时emptyText传值问题
在Extjs4中,form提交时,文本框的emptyText会传到后台,比如 上图中的“请选择”这样的文本会作为值传到后台. 解决方法: form提交时配置 submitEmptyText: fal ...
- SpringMVC + MyBatis 配置文件
web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="htt ...
- SqlServer还原步骤
SqlServer还原步骤 2009-09-05 10:32:12| 分类: 数据库|字号 订阅 1 . 删除原有数据库 新建数据库 hywlxt 2. 在master 中新建存储过程 k ...
- bzoj2120 数颜色——带修莫队
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2120 带修改的莫队: 用结构体存下修改和询问,排好序保证时间后就全局移动修改即可: 参考了T ...
- bzoj1231 [Usaco2008 Nov]mixup2 混乱的奶牛——状压DP
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1231 小型状压DP: f[i][j] 表示状态为 j ,最后一个奶牛是 i 的方案数: 所以 ...
- 协议-网络-安全协议:SSH(安全外壳协议)
ylbtech-协议-网络-安全协议:SSH(安全外壳协议) SSH 为 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定:SSH 为建立 ...
- css中标签,类名,id名的命名 语义化命名
作为前端开发人,经常头疼于雷鸣,标签,id名的命名,不知道应该基于什么原则. 原则: 2 当命名的时候,问自己,这个元素是要来做什么?(根据使用目的).ad-banner 4 避免依靠位置和视觉效果命 ...