洛谷 P4663 - [BalticOI 2008]魔法石(dp)
A:我该是有多无聊来写这种题的题解啊
B:大概是因为这题题解区里没有题解所以我来写一篇了,说明我有高尚的济世情怀(大雾
跑题了跑题了
首先看到字典序第 \(i\) 小小可以自然地想到按位决策,也就是说从高位到低位枚举,对于每一位我们强制令它为 I
,看看有多少个符合要求的字符串,如果小于 \(i\) 就将这位改为 \(1\) 并继续往下枚举。
那么怎么求有多少个符合要求的字符串呢?这时候就要用到 DP 了。显然一个字符串可以成为某个字符串的正规读法当且仅当它的字典序 \(\le\) 反串的字典序,因此我们很容易设计出一个 \(dp\) 状态:\(dp_{i,j,o,x,y}\) 表示当前决策了字符串的前 \(i\) 位和后 \(i\) 位,有 \(j\) 对 XI
相邻,\(o\) 表示反串字典序是否等于原串字典序,从前往后数第 \(i\) 位为 \(x\),从后往前数第 \(i\) 位为 \(y\) 的方案数。转移就枚举第 \(i+1\) 位填的数 \(u\) 和第 \(n-i\) 位填的数 \(v\),如果 \(o=1\) 且 \(u>v\) 就会导致原串字典序 \(>\) 反串字典序,不合法。否则显然有如下转移方程式子:
- \(dp_{i+1,j+[u\ne x]+[v\ne y],o\land[u==v],u,v}\leftarrow dp_{i,j,o,x,y}\)
注意特判 \(i+1=n-i\) 的情况和 \(i+2=n-i\) 的情况,对于前者而言必须有 \(u=v\),因为它俩是同一位,对于后者而言转移的第二维还需额外加上 \([u\ne v]\)。
时间复杂度 \(32n^3\),跑得飞快(
const int MAXN=60;
const char str[3]="IX";
int n,k;ll m,dp[MAXN+5][MAXN+5][2][2][2];
int lim[MAXN+5];
ll calc(){
memset(dp,0,sizeof(dp));
for(int a=0;a<2;a++) for(int b=a;b<2;b++){
if(~lim[1]&&(lim[1]^a)) continue;
if(~lim[n]&&(lim[n]^b)) continue;
dp[1][0][a==b][a][b]=1;
} ll ans=0;
for(int i=1;(i<<1|1)<=n;i++) for(int j=0;j<=k;j++)
for(int o=0;o<2;o++) for(int x=0;x<2;x++) for(int y=0;y<2;y++){
if(!dp[i][j][o][x][y]) continue;
if((i<<1|1)==n){
for(int u=0;u<2;u++){
if(~lim[i+1]&&(lim[i+1]^u)) continue;
if(j+(u^x)+(u^y)<=k) ans+=dp[i][j][o][x][y];
}
} else{
for(int u=0;u<2;u++) for(int v=0;v<2;v++){
if(~lim[i+1]&&(lim[i+1]^u)) continue;
if(~lim[n-i]&&(lim[n-i]^v)) continue;
if(o&&u>v) continue;
if((i+1<<1)==n){
if(j+(u^x)+(u^v)+(v^y)<=k) ans+=dp[i][j][o][x][y];
} else dp[i+1][j+(u^x)+(v^y)][o&&u==v][u][v]+=dp[i][j][o][x][y];
}
}
}
return ans;
}
int main(){
scanf("%d%d%lld",&n,&k,&m);
if(n==1) return ((m>2)?puts("NO SUCH STONE"):(putchar(str[m-1]))),0;
if(n==2){
if(k==0) return ((m>2)?puts("NO SUCH STONE"):(putchar(str[m-1]),putchar(str[m-1]))),0;
else return ((m>3)?puts("NO SUCH STONE"):((m&1)?(putchar(str[m>>1]),putchar(str[m>>1])):puts("IX"))),0;
} memset(lim,-1,sizeof(lim));
if(m>calc()) return puts("NO SUCH STONE")&0;
for(int i=1;i<=n;i++){
lim[i]=0;ll sum=calc();
if(m>sum) m-=sum,lim[i]=1;
}
for(int i=1;i<=n;i++) putchar(str[lim[i]]);
return 0;
}
洛谷 P4663 - [BalticOI 2008]魔法石(dp)的更多相关文章
- 洛谷P2507 [SCOI2008]配对 题解(dp+贪心)
洛谷P2507 [SCOI2008]配对 题解(dp+贪心) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1299251 链接题目地址:洛谷P2507 [S ...
- 洛谷 P4665 [BalticOI 2015]Network
洛谷 P4665 [BalticOI 2015]Network 你有一棵 $ n $ 个节点的树,你可以在树上加一些边,使这棵树变成一张无重边.自环的图,且删掉任意一条边它仍然联通.求最少要加多少条边 ...
- 洛谷 P3177 [HAOI2015]树上染色 树形DP
洛谷 P3177 [HAOI2015]树上染色 树形DP 题目描述 有一棵点数为 \(n\) 的树,树边有边权.给你一个在 \(0 \sim n\)之内的正整数 \(k\) ,你要在这棵树中选择 \( ...
- 洛谷 P4072 [SDOI2016]征途 斜率优化DP
洛谷 P4072 [SDOI2016]征途 斜率优化DP 题目描述 \(Pine\) 开始了从 \(S\) 地到 \(T\) 地的征途. 从\(S\)地到\(T\)地的路可以划分成 \(n\) 段,相 ...
- 洛谷P1880 石子合并(区间DP)(环形DP)
To 洛谷.1880 石子合并 题目描述 在一个园形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分. 试设计出1 ...
- 洛谷P1063 能量项链(区间DP)(环形DP)
To 洛谷.1063 能量项链 题目描述 在Mars星球上,每个Mars人都随身佩带着一串能量项链.在项链上有N颗能量珠.能量珠是一颗有头标记与尾标记的珠子,这些标记对应着某个正整数.并且,对于相邻的 ...
- 洛谷P1282 多米诺骨牌 (DP)
洛谷P1282 多米诺骨牌 题目描述 多米诺骨牌有上下2个方块组成,每个方块中有1~6个点.现有排成行的 上方块中点数之和记为S1,下方块中点数之和记为S2,它们的差为|S1-S2|.例如在图8-1中 ...
- 洛谷 P5469 - [NOI2019] 机器人(区间 dp+拉格朗日插值)
洛谷题面传送门 神仙题,放在 D1T2 可能略难了一点( 首先显然对于 P 型机器人而言,将它放在 \(i\) 之后它会走到左边第一个严格 \(>a_i\) 的位置,对于 Q 型机器人而言,将它 ...
- 【题解】洛谷P4158 [SCOI2009] 粉刷匠(DP)
次元传送门:洛谷P4158 思路 f[i][j][k][0/1]表示在坐标为(i,j)的格子 已经涂了k次 (0是此格子涂错 1是此格子涂对)涂对的格子数 显然的是 每次换行都要增加一次次数 那么当j ...
随机推荐
- 【UE4 C++】Slate 初探: Editor UI 与 Game UI
概述 名词区分 Slate Slate 是完全自定义.与平台无关的UI框架 应用 可用于编辑器UI,编辑器的大部分界面都是使用 Slate 构建的 可做为游戏UI 可作为独立应用开发 只能 C++ 开 ...
- [no code][scrum meeting] Alpha 5
项目 内容 会议时间 2020-04-10 会议主题 后端技术讨论 会议时长 30min 参会人员 全体成员 $( "#cnblogs_post_body" ).catalog() ...
- Asp.net Core C#进行筛选、过滤、使用PredicateBuilder进行动态拼接lamdba表达式树并用作条件精准查询,模糊查询
在asp.net core.asp.net 中做where条件过滤筛选的时候写的长而繁琐不利于维护,用PredicateBuilder进行筛选.过滤.LInq配合Ef.core进行动态拼接lamdba ...
- numpy.zeros()的作用和实操
numpy.zeros()的作用: 通常是把数组转换成想要的矩阵 numpy.zeros()的使用方法: zeros(shape, dtype=float, order='C') shape:数据尺寸 ...
- 洛谷 P4867 Gty的二逼妹子序列
链接: P4867 题意: 给出长度为 \(n(1\leq n\leq 10^5)\) 的序列 \(s\),保证\(1\leq s_i\leq n\).有 \(m(1\leq m\leq 10^6)\ ...
- Spring源码解读(一):Spring的背景起源及框架整体介绍
一.前言 Spring起源于2002年Rod Johnson写的一本书<Expert One-on-One J2EE>,书里介绍了Java企业应用程序开发情况,并指出Java EE和EJB ...
- (类)Program1.1
1 class MyClass: 2 3 i = 12345 4 5 def __init__(self): 6 self.data = "WOOWOWOWO" 7 8 def f ...
- Filter学习笔记
博客园的编辑器太丑了,所以我换用了别的Markdown编辑器,并用图片形式上传.
- tomcat9启动报错too low setting for -Xss
在tomcat下部署war包启动时报错,关键错误信息如下: Caused by: java.lang.IllegalStateException: Unable to complete the sca ...
- 13.Fibonacci数
描述 无穷数列1,1,2,3,5,8,13,21,34,55...称为Fibonacci数列,它可以递归地定义为 F(n)=1 ...........(n=1或n=2) F(n)=F(n-1)+F(n ...