首页 > 代码库 > 【BZOJ1367】[Baltic2004]sequence 左偏树
【BZOJ1367】[Baltic2004]sequence 左偏树
【BZOJ1367】[Baltic2004]sequence
Description
Input
Output
一个整数R
Sample Input
7
9
4
8
20
14
15
18
9
4
8
20
14
15
18
Sample Output
13
HINT
所求的Z序列为6,7,8,13,14,15,18.
R=13
题解:详见论文
然而本题要求z[i]严格递增,那就让所有t[i]-=i就好了
#include <cstdio>#include <cstring>#include <iostream>using namespace std;const int maxn=1000010;int v[maxn];int l[maxn],r[maxn],rt[maxn],nvl[maxn],ch[maxn][2];int n,m;int merge(int x,int y){ if(!x) return y; if(!y) return x; if(v[x]<v[y]) swap(x,y); ch[x][1]=merge(ch[x][1],y); if(nvl[ch[x][0]]<nvl[ch[x][1]]) swap(ch[x][0],ch[x][1]); nvl[x]=nvl[ch[x][1]]+1; return x;}long long ans;long long z(int a){ return (long long)(a>0?a:-a);}int main(){ scanf("%d",&n); int i,j; for(i=1;i<=n;i++) scanf("%d",&v[i]),v[i]-=i; for(i=1;i<=n;i++) { l[++m]=r[m]=rt[m]=i; while(v[rt[m]]<v[rt[m-1]]&&m>1) { rt[m-1]=merge(rt[m-1],rt[m]); for(j=1;j<=(r[m-1]-l[m-1]+1)/2+1+(r[m]-l[m]+1)/2+1-(r[m]-l[m-1]+1)/2-1;j++) rt[m-1]=merge(ch[rt[m-1]][0],ch[rt[m-1]][1]); r[m-1]=r[m],m--; } } for(i=1;i<=m;i++) for(j=l[i];j<=r[i];j++) ans+=z(v[rt[i]]-v[j]); printf("%lld",ans); return 0;}
【BZOJ1367】[Baltic2004]sequence 左偏树
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。