洛谷$P4331\ [BOI2004]\ Sequence$ 数字序列 左偏树
正解:左偏树
解题报告:
开始看到的时候$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$ 数字序列 左偏树的更多相关文章
- 洛谷P4331 [BOI2004] Sequence 数字序列 [左偏树]
题目传送门 数字序列 题目描述 给定一个整数序列 a1,a2,⋅⋅⋅,an ,求出一个递增序列 b1<b2<⋅⋅⋅<bn ,使得序列 ai 和 bi 的各项之差的绝对 ...
- Luogu P4331 [BOI2004]Sequence 数字序列 (左偏树论文题)
清晰明了%%% Fairycastle的博客 个人习惯把size什么的存在左偏树结点内,这样在外面好写,在里面就是模板(只用修改update). 可以对比一下代码(好像也差不多-) MY CODE # ...
- 洛谷P4331 [BOI2004]Sequence 数字序列(左偏树)
传送门 感觉……不是很看得懂题解在说什么? 我们先把原数列$a_i-=i$,那么本来要求递增序列,现在只需要求一个非严格递增的就行了(可以看做最后每个$b_i+=i$,那么非严格递增会变为递增) 如果 ...
- 洛谷P4331[BOI2004] sequence
博客复活? 这个题很模板啊.随便上个左偏树.之前第一遍写对了.然后今天翻出来又写了一遍发现了一个奇奇怪怪的问题. 对比如下 上面的是AC 下面的WA 真的是一个很蠢的问题...你TM堆顶都弹出来了,堆 ...
- 洛谷.3273.[SCOI2011]棘手的操作(左偏树)
题目链接 还是80分,不是很懂. /* 七个操作(用左偏树)(t2表示第二棵子树): 1.合并:直接合并(需要将一个t2中原有的根节点删掉) 2.单点加:把这个点从它的堆里删了,加了再插入回去(有负数 ...
- 洛谷P3273 [SCOI2011] 棘手的操作 [左偏树]
题目传送门 棘手的操作 题目描述 有N个节点,标号从1到N,这N个节点一开始相互不连通.第i个节点的初始权值为a[i],接下来有如下一些操作: U x y: 加一条边,连接第x个节点和第y个节点 A1 ...
- 洛谷P3066 [USACO12DEC] 逃跑的Barn [左偏树]
题目传送门 逃跑的Barn 题目描述 It's milking time at Farmer John's farm, but the cows have all run away! Farmer J ...
- 模板 可并堆【洛谷P3377】 【模板】左偏树(可并堆)
P3377 [模板]左偏树(可并堆) 如题,一开始有N个小根堆,每个堆包含且仅包含一个数.接下来需要支持两种操作: 操作1: 1 x y 将第x个数和第y个数所在的小根堆合并(若第x或第y个数已经被删 ...
- P4331 [BOI2004]Sequence 数字序列 (左偏树)
[题目链接] https://www.luogu.org/problemnew/show/P4331 题目描述 给定一个整数序列\(a_1, a_2, ··· , a_n,\)求出一个递增序列\(b_ ...
随机推荐
- mysql 开篇
Mysql 教程 mysql是最流行的关系型数据库管理系统,在wab应用方面mysql是最好的RDBMS(Relational Database Manangement System: 关系数据库管理 ...
- day5_python之hashlib模块
用来校验文本内容hash:一种算法 ,3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法三个特点:1.内容相同则h ...
- poj1741 树上距离小于等于k的对数 点分治 入门题
#include <iostream> #include <stdio.h> #include <string.h> #include <algorithm& ...
- Android Listview中Button按钮点击事件冲突解决办法
今天做项目时,ListView中含有了Button组件,心里一早就知道肯定会有冲突,因为以前就遇到过,并解决过,可惜当时没有记录下来. 今天在做的时候,继续被这个问题郁闷了一把,后来解决后,赶紧来记录 ...
- 全面理解Python中的类型提示(Type Hints)
众所周知,Python 是动态类型语言,运行时不需要指定变量类型.这一点是不会改变的,但是2015年9月创始人 Guido van Rossum 在 Python 3.5 引入了一个类型系统,允许开发 ...
- Python--day66--Django模板语言关于静态文件路径的灵活写法
静态文件路径的灵活写法: 正规的讲解: 静态文件相关 {% static %} {% load static %} <img src="{% static "images/h ...
- hdu 1016 Prime Ring Problem(dfs)
Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- mybatis 一对多查询 集合创建空对象的问题
在做 mybatis 一对多查询的时候, resultMap 里面用到了集合标签 collection ,后来发现 当该条数据没有子集的时候, collection 会自动创建一个属性都是null的对 ...
- Hibernate @OneToOne懒加载实现解决方案
在hibernate注解(三)中,我提高过一对一(@OneToOne)懒加载失效的问题.虽然给出了解决方法,但并没有给出完整的解决方案.今天我专门针对该问题进行讨论.至于懒加载失效的原因,在之前的文章 ...
- Java语言中的正则表达式
正则表达式是什么? 正则表达式是一种强大而灵活的文本处理工具.初学正则表达式时,其语法是一个难点,但它确实是一种简洁.动态的语言.正则表达式提供了一种完全通用的方式,能够解决各种字符串处理相关的问题: ...