正解:左偏树

解题报告:

传送门$QwQ$

开始看到的时候$jio$得长得很像之前做的一个$dp$,,,

但是$dp$那题是说不严格这里是严格?

不难想到我们可以让$a_{i},b_{i}$同时减去$i$这样就变成那道题辣,,,?$QwQ$

但是如果$dp$的话复杂度是$O(n^2)$的就假了$QwQ$

这里介绍一个左偏树做法,复杂度是$O(nlogn)$的$QwQ$

先考虑两个特殊情况,分别是$a$递减和$a$递增$QwQ$?

递增很显然就$b_{i}=a_{i}$就成$QwQ$

然后如果是递减,小学奥数得当$b$为中位数时有$min$

然后现在考虑把$a$拆成若干个区间,考虑怎么合并$QwQ$

假如现在要合并的区间的$b$分别是$b_{1},b_{2}$

如果$b_{1}\leq b_{2}$,欧克直接合并就成

否则就考虑继续找中位数?

所以现在就变成了动态维护中位数$QwQ$

这个似乎在基础算法里港过?就说开两个堆然后不停地$push\ pop$就好$QwQ$

但是这题里面是要合并的嘛,所以就用左偏树就成?

具体来说就考虑,对长度为$x$的序列,就把前$\frac{x}{2}$小的数放到左偏树里面,每次合并就合并两个左偏树,中位数就是堆顶

$umm$然后其实我$jio$得代码实现还是有点儿难度的,,,?

所以我我我我给$code$里打了点儿注释$w$

然后记得开$ll$,,,$100pts->10pts$真的很难受,,,$QwQQQQQQ$

#include<bits/stdc++.h>
using namespace std;
#define il inline
#define int long long
#define mp make_pair
#define gc getchar()
#define P pair<int,int>
#define ri register int
#define rc register char
#define rb register bool
#define t(i) edge[i].to
#define t_nw(i) edge_nw[i].to
#define rp(i,x,y) for(ri i=x;i<=y;++i)
#define e(i,x) for(ri i=head[x];i;i=edge[i].nxt)
#define e_nw(i,x) for(ri i=head_nw[x];i;i=edge_nw[i].nxt) const int N=+;
int n,a[N],tp[N],ed[N],top,ls[N],rs[N],dis[N],as;//tp是堆顶ed是范围 il int read()
{
rc ch=gc;ri x=;rb y=;
while(ch!='-' && (ch<'' || ch>''))ch=gc;
if(ch=='-')ch=gc,y=;
while(''<=ch && ch<='')x=(x<<)+(x<<)+(ch^''),ch=gc;
return y?x:-x;
}
int merg(ri x,ri y)
{
if(!x || !y)return x|y;
if(a[x]<a[y])swap(x,y);
rs[x]=merg(rs[x],y);if(dis[ls[x]]<dis[rs[x]])swap(ls[x],rs[x]);
dis[x]=dis[rs[x]]+;return x;
} signed main()
{
//freopen("4331.in","r",stdin);freopen("4331.out","w",stdout);
n=read();rp(i,,n)a[i]=read()-i;
rp(i,,n)
{
tp[++top]=i;ed[top]=i;
while(top> && a[tp[top]]<a[tp[top-]])
{
--top;tp[top]=merg(tp[top],tp[top+]);
if((ed[top+]-ed[top])& && (ed[top]-ed[top-])&)tp[top]=merg(ls[tp[top]],rs[tp[top]]);//可以用前面动态维护中位数的思考,就这个可并堆记的都只有1/2的小的那一半数嘛,然后如果合并的两个堆都是奇数,合并之后就会是偶数,就会要把最大的那个数弹到存大的那一半数的堆.因为这里并没开这个堆所以直接弹掉就成QwQ
ed[top]=ed[top+];
}
}
rp(i,,top)rp(j,ed[i-]+,ed[i])as+=abs(a[tp[i]]-a[j]);
printf("%lld\n",as);
rp(i,,top)rp(j,ed[i-]+,ed[i])printf("%lld ",a[tp[i]]+j);
return ;
}

洛谷$P4331\ [BOI2004]\ Sequence$ 数字序列 左偏树的更多相关文章

  1. 洛谷P4331 [BOI2004] Sequence 数字序列 [左偏树]

    题目传送门 数字序列 题目描述 给定一个整数序列 a1​,a2​,⋅⋅⋅,an​ ,求出一个递增序列 b1​<b2​<⋅⋅⋅<bn​ ,使得序列 ai​ 和 bi​ 的各项之差的绝对 ...

  2. Luogu P4331 [BOI2004]Sequence 数字序列 (左偏树论文题)

    清晰明了%%% Fairycastle的博客 个人习惯把size什么的存在左偏树结点内,这样在外面好写,在里面就是模板(只用修改update). 可以对比一下代码(好像也差不多-) MY CODE # ...

  3. 洛谷P4331 [BOI2004]Sequence 数字序列(左偏树)

    传送门 感觉……不是很看得懂题解在说什么? 我们先把原数列$a_i-=i$,那么本来要求递增序列,现在只需要求一个非严格递增的就行了(可以看做最后每个$b_i+=i$,那么非严格递增会变为递增) 如果 ...

  4. 洛谷P4331[BOI2004] sequence

    博客复活? 这个题很模板啊.随便上个左偏树.之前第一遍写对了.然后今天翻出来又写了一遍发现了一个奇奇怪怪的问题. 对比如下 上面的是AC 下面的WA 真的是一个很蠢的问题...你TM堆顶都弹出来了,堆 ...

  5. 洛谷.3273.[SCOI2011]棘手的操作(左偏树)

    题目链接 还是80分,不是很懂. /* 七个操作(用左偏树)(t2表示第二棵子树): 1.合并:直接合并(需要将一个t2中原有的根节点删掉) 2.单点加:把这个点从它的堆里删了,加了再插入回去(有负数 ...

  6. 洛谷P3273 [SCOI2011] 棘手的操作 [左偏树]

    题目传送门 棘手的操作 题目描述 有N个节点,标号从1到N,这N个节点一开始相互不连通.第i个节点的初始权值为a[i],接下来有如下一些操作: U x y: 加一条边,连接第x个节点和第y个节点 A1 ...

  7. 洛谷P3066 [USACO12DEC] 逃跑的Barn [左偏树]

    题目传送门 逃跑的Barn 题目描述 It's milking time at Farmer John's farm, but the cows have all run away! Farmer J ...

  8. 模板 可并堆【洛谷P3377】 【模板】左偏树(可并堆)

    P3377 [模板]左偏树(可并堆) 如题,一开始有N个小根堆,每个堆包含且仅包含一个数.接下来需要支持两种操作: 操作1: 1 x y 将第x个数和第y个数所在的小根堆合并(若第x或第y个数已经被删 ...

  9. P4331 [BOI2004]Sequence 数字序列 (左偏树)

    [题目链接] https://www.luogu.org/problemnew/show/P4331 题目描述 给定一个整数序列\(a_1, a_2, ··· , a_n,\)求出一个递增序列\(b_ ...

随机推荐

  1. Part10-字符型设备驱动模型-part10.1-使用字符型设备

    ‘ ’

  2. Top 10 open source projects of 2015

    Top 10 open source projects of 2015 Posted 15 Dec 2015Jen Wike Huger (Red Hat)Feed 188 up 31 comment ...

  3. 怎样打开.jar格式文件,怎样运行.jar格式文件

    当时第一次看到.jar文件不知道是什么鬼,以为是压缩包,直接就解压了,但是并没有什么用.所以在下为大家详细介绍如何打开.jar文件以及如何运行.jar文件.什么是.jar文件,简单的说就是java压缩 ...

  4. Java Annotation详解(二): 反射和Annotation

    前面一篇文<Java Annotation详解(一): 理解和使用Annotation>中,我们或许会觉得,Annotation注释其实并没有多大的作用,除了几个内建的Annotation ...

  5. Python--day70--csrf简单用法、 跨站请求伪造和csrf_token使用

    1,csrf简单用法 2,Django里面的setting加入了防跨站伪造:这段代码帮你生成特殊字符串,帮你塞到html页面中来 3,csrf_token使用:

  6. hdu 1045 Fire Net(dfs)

    Fire Net Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  7. RBF神经网络的matlab简单实现

    径向基神经网络 1.径向基函数 (Radial Basis Function,RBF) 神经网络是一种性能良好的前向网络,具有最佳逼近.训练简洁.学习收敛速度快以及克服局部最小值问题的性能,目前已经证 ...

  8. springboot 项目打包可运行jar文件

    eclipse 运行run as  maven bulid  ,填入package ,运行打包 java -jar xxx.jar

  9. Python--day26--反射

    反射对象的属性:(非常重要) getattr(类名,‘属性名’):获得属性值 使用getattr的好处:需要查看某个属性值的时候,不用再在代码中用if else elif 去判断输入(input函数) ...

  10. HDU 5971"Wrestling Match"(二分图染色)

    传送门 •题意 给出 n 个人,m 场比赛: 这 m 场比赛,每一场比赛中的对决的两人,一个属于 "good player" 另一个属于 "bad player" ...