码迷,mamicode.com
首页 > 其他好文 > 详细

排座位&&Little Elephant And Permutation——排列dp的处理

时间:2018-10-06 21:34:25      阅读:208      评论:0      收藏:0      [点我收藏+]

标签:部分   tle   rac   alt   序列   直接   概念   blog   大小   

排列的问题,就是要把序列排个序,使之达到某种最优值或者统计方案数

dp可以解决部分排列问题。

通常的解决方案是,按照编号(优先级)排序决策,从左到右决策两种。

这里主要是第一个。

 

排座位
? 有 ?? 个人坐成一排
? 对于相邻两个人 ??, ??
? 如果 ?? < ??,则会产生 ???? + ???? 的愉悦度
? 否则会产生 ???? + ???? 的愉悦度
? 求一个排列让最大化愉悦度
? ?? ≤ 3000

从左到右决策,肯定就要状压了。

但是可以发现,我们并不关心一个i左右是谁,只关心编号和i的相对大小。

而且,这个贡献ai,bj,ci,dj是可以独立的。

思路就比较自然了。

我们按照编号从小到大决策。

每个点i的放置有几种:

1.左右都比i小。

2/3.左/右比i大。

4.左右都比i大。

 

但是麻烦的是,如果直接dp可能最后形成不了一个序列。

不是一个整段。

所以,还要引入段的概念。

 

i的决策是:

1.左右都比i小,即连接之前的两个段。

2/3.左/右比i大,另一个比i小,即连接一个段。

4.左右都比i大,即i自成一段。

每种中,i对答案的贡献可以现场统计。

因为,我们的编号是从小到大处理的,

如果我们能够正确连接的话,这个贡献一定是可以算上的。

 

f[i][j]表示,处理完前编号i个,形成了j段的方案数。

 

还有一个问题是,边界情况,没有左/右,没有这个贡献。

那么可以f[i][j][0/1][0/1]表示是否放了最左边最右边的。

答案:f[n][1][1][1]

 

 

技术分享图片

Solution :

假定ai是一个1~n的数列。

对于合法的bi数列,乘上n!就是所有的ai和bi的情况了。

 

这样,贡献就比较好统计了。

dp[i][j][k]表示,处理bi中前i个位置,有j个是空的,贡献是k的方案数。

看这篇题解:

 

其实还有一个题:(虽然不是dp)

有趣的家庭菜园

排座位&&Little Elephant And Permutation——排列dp的处理

标签:部分   tle   rac   alt   序列   直接   概念   blog   大小   

原文地址:https://www.cnblogs.com/Miracevin/p/9748363.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!