---恢复内容开始---

题意:
t组数据,每组数据给出n个木棒,长度由1到n,除了两端的木棒外,每一根木棒,要么比它左右的两根都长,要么比它左右的两根都短。即要求构成的排列为波浪型。对符合要求的排列按字典序(从左到右,从低到高)进行排序,求排列序号为c的排列。

刚拿到这道题时,也是一脸懵逼,感觉起来要用dp,但又不知道从哪里去下手。在网上搜了一下才大概明白。

我们可以先定义状态f[i]表示第i个木棒的合法方案数,我们考虑去转移,怎么从f[i-j]转移到f[i]呢?我们就要考虑第i-j个木棒的长度以及第i个木棒的长度关系,我们把下降的方案称为down,上升的称为up,我们将i根木棒构成的合法集合称为S(i)。

我们在选定x作为第一根木棒之后,去选择第二个木棒y,此时我们要去考虑x,y的长度关系,而在选定y之后我们又要考虑y和下一根木棒长度的关系,并且当方案不符合时我们也不便于去重新选择,此时我们的方程很难进行转移。

我们便可以考虑在此基础上进行细化f[i]=f[i][k] (k=1....i)

我们再定义状态f[i][j]表示集合S(i)中以第j短的木棒为第一个的方案数那么我们便可以写出状态转移方程

f[i][j]= \(\sum_{m=j}^p\) f[i][m] (down) + \(\sum_{n=1}^q\) f[i][n] (up) (p=i-1,q=j-1)

我们发现这个方程仍然不好转移,因为它还是没有拜托前面的约束。我们便可在问题上再进行细分

f[i][j]=f[i][j][down]+f[i][j][up]

f[i][j][[down]表示i根木棒以第j短的木棒为首的下降方案数,我们再去考虑状态转移方程

f[i[[j][down]= \(\sum_{n=1}^q\)f[i-1][n][up]

f[i[[j][up]= \(\sum_{m=j}^p\)f[i-1][m][down]

(p=i-1,q=j-1)

至此我们可以得出一个技巧,当在做dp类型的题目时,状态不好进行转移时我们可以在此基础上增加一维,如blocks,便于转移

至此问题还并没有得到解决,题目要求序列为c的方案,那么我们又改如何去求到呢?我们考虑以第1短的木棒为第一个的方案p(1),若c>p(1)则说明c不在p(1)之中,c减去p(1),我们再去考虑p(2),若还大于,则类推,当c<=p(k)时我们便可确定c在以第k短的木棒为第一根的集合内,我们再去考虑第二根,以此类推下去,求得解。

代码

#include<bits/stdc++.h>
using namespace std;
int T,n,used[25];
long long f[25][25][2],c;//0->up,1->down
void sta(int n){
memset(f,0,sizeof(f));
f[1][1][0]=f[1][1][1]=1;
for(int i=2;i<=n;++i){
for(int j=1;j<=i;++j){
for(int M=j;M<i;++M) f[i][j][0]+=f[i-1][M][1];
for(int N=1;N<j;++N) f[i][j][1]+=f[i-1][N][0];
}
}
}
void print(int n,long long cc){
long long jump=0;
int a[25];
memset(used,0,sizeof(used));
for(int i=1;i<=n;++i){
long long tmp=jump;
int k,p=0;
for(k=1;k<=n;++k){
tmp=jump;
if(!used[k]){
++p;
if(i==1) jump+=f[n][p][1]+f[n][p][0];
else{
if(k>a[i-1]&&(i<=2||a[i-2]>a[i-1])) jump+=f[n-i+1][p][1];
if(k<a[i-1]&&(i<=2||a[i-2]<a[i-1])) jump+=f[n-i+1][p][0];
}
if(jump>=cc) break;
}
}
used[k]=1;
a[i]=k;
jump=tmp;
}
for(int i=1;i<=n;++i){
printf("%d ",a[i]);
if(i==n) printf("\n");
}
}
int main(){
scanf("%d",&T);
sta(20);
while(T--){
scanf("%d %lld",&n,&c);
print(n,c);
}
return 0;
}

---恢复内容结束---

poj1037 [CEOI 2002]A decorative fence 题解的更多相关文章

  1. POJ1037 A decorative fence

    题意 Language:Default A decorative fence Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 84 ...

  2. POJ1037 A decorative fence 【动态规划】

    A decorative fence Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 6489   Accepted: 236 ...

  3. A decorative fence

    A decorative fence 在\(1\sim n\)的全排列\(\{a_i\}\)中,只有大小交错的(即任意一个位置i满足\(a_{i-1}<a_i>a_{i+1}ora_{i- ...

  4. 【POJ1037】A decorative fence(DP)

    BUPT2017 wintertraining(15) #6C 题意 给长度n的数列,1,2,..,n,按依次递增递减排序,求字典序第k小的排列. 题解 dp. up[i][j]表示长度为j,以第i小 ...

  5. $Poj1037\ A\ Decorative\ Fence$ 计数类$DP$

    Poj  AcWing Description Sol 这题很数位$DP$啊, 预处理$+$试填法 $F[i][j][k]$表示用$i$块长度不同的木板,当前木板(第$i$块)在这$i$块木板中从小到 ...

  6. poj 1037 A decorative fence

    题目链接:http://poj.org/problem?id=1037 Description Richard just finished building his new house. Now th ...

  7. OpenJ_Bailian - 1037 A decorative fence

    Discription Richard just finished building his new house. Now the only thing the house misses is a c ...

  8. usaco 2002 月赛 Fiber Communications 题解

    Description Farmer John wants to connect his N (1 <= N <= 1,000) barns (numbered 1..N) with a ...

  9. POJ1821 Fence 题解报告

    传送门 1 题目描述 A team of $k (1 <= K <= 100) $workers should paint a fence which contains \(N (1 &l ...

随机推荐

  1. Mobile game forensics

    My friend Carrie'd like to know "Garena 传说对决" violates any mobile risks such as insecure d ...

  2. 从源码看java线程状态

    关于java线程状态,网上查资料很混乱,有的说5种状态,有的说6种状态,初学者搞不清楚这个线程状态到底是怎么样的,今天我讲一下如何看源码去解决这个疑惑. 直接上代码: public class Thr ...

  3. 大型系列课程之-七夕告白之旅Electron篇

    上一篇分享了一下vbs的撩妹攻略,但细心的兄弟会发现,这种脚本式的攻城方案并不得心应手,有很多妹子害怕是病毒根本不敢点击,而且这个脚本界面风格也不漂亮,不能轻易打动妹子的心,怎么破,小编这次在为各位老 ...

  4. Canvas动画(PC端 移动端)

    Canvas动画(PC端 移动端) 一,介绍与需求 1.1,介绍 canvas是HTML5中新增一个HTML5标签与操作canvas的javascript API,它可以实现在网页中完成动态的2D与3 ...

  5. 浅谈微服务架构与服务治理的Eureka和Dubbo

    前言 本来计划周五+周末三天自驾游,谁知人算不如天算,周六恰逢台风来袭,湖州附近的景点全部关停,不得已只能周五玩完之后,于周六踩着台风的边缘逃回上海.周末过得如此艰难,这次就聊点务虚的话题,一是浅谈微 ...

  6. H5 Handlebars的简单使用

    扫码关注公众号,不定期更新干活 web 开发中,js 解析JSON 是经常的事情.非常繁琐.handlebars 使用了模版,只要你定义一个模版,提供一个json对象,handlebars 就能吧js ...

  7. WPF中TimeSpan的坑

    记一次在WPF中,在将格式为“DD.HH:mm:ss”字符串转换成TimeSpan时遇到的坑 如果字符串为:DD.HH:mm:ss,转换结果正确.例如: var currentValue = &quo ...

  8. js网页倒计时功能(天,时,分,秒)

    给定任何一个时间,然后实现现在到那个时间的倒计时. 下面的例子是显示现在到2019年8月1号0时0分的倒计时: <div class="list"> <span ...

  9. 「雕爷学编程」Arduino动手做(9)——火焰传感器模块

    37款传感器和模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器与模块,依照实践出真知(动手试试)的理念,以学习和交流为目的,这里准备 ...

  10. hadoop2.7+spark2.2+zookeeper3.4.简单安装

    1.zookeeper的安装##配置/etc/hosts192.168.88.130 lgh192.168.88.131 lgh1192.168.88.132 lgh2 ##安装java8 解压配置环 ...