洛谷 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 ...
随机推荐
- relativeLayout相对布局的嵌套在py中的引用
from kivy.app import App from kivy.uix.button import Button from kivy.uix.relativelayout import Rela ...
- springboot整合rabbitmq实现生产者消息确认、死信交换器、未路由到队列的消息
在上篇文章 springboot 整合 rabbitmq 中,我们实现了springboot 和rabbitmq的简单整合,这篇文章主要是对上篇文章功能的增强,主要完成如下功能. 需求: 生产者在启 ...
- 关于QGIS的插件开发(C++)
关于C++插件的开发材料较少,根据网上的指导,我采用了早期版本的插件模板生成的方法来创建QGIS的插件,其方法是从以前版本(2.18.25)里面拷贝插件模板的方法进行,具体的执行步骤为 1.拷贝文件 ...
- BOOST内存管理-intrusive_ptr
参考链接https://blog.csdn.net/harbinzju/article/details/6754646 intrusive_ptr 是shared_ptr的插入式版本.与shared_ ...
- Nginx(三):Linux环境(Ubuntu)下Nginx的安装
Nginx 是一位俄罗斯人 Igor Sysoev(伊戈尔·塞索斯夫)编写的一款高性能HTTP和反向代理服务器. Nginx 主要是有C编写的,安装Nginx需要GCC编译器(GNU Compiler ...
- 身份证归属地查询免费api接口
描写叙述 :依据身份证编号 查询归属地信息. 调用地址: http://api.k780.com:88/? app=idcard.get&idcard=510103195309280011&a ...
- wpa_supplicant启动出错rfkill: Cannot open RFKILL control device
在板子是调试网络,千辛万苦把wpa_supplicant及其依赖都移植编译进来了,在板子上调试启动的时候启动报错了 D/wpa_supplicant( 1152): wpa_supplicant v2 ...
- JAVA笔记4__static关键字/对象数组/foreach/方法的可变参数
/** * static关键字:修饰属性(实质就是全局变量).方法(无需本类的对象即可调用此方法).类. * 1.static方法只能调用static方法 * 2.static方法只能访问static ...
- Spring事务不生效问题
事务未生效可能造成严重的数据不一致性问题,因而保证事务生效至关重要.Spring事务是通过Spring aop实现的,所以不生效的本质问题是spring aop没生效,或者说没有代理成功,所以有必要了 ...
- 更改mysql数据库根目录
1,查看原根目录 2,然后关闭数据库服务 3,cp -r 源根目录到目的根目录 4,修改my.cnf文件定义的根目录位置到目的根目录 5,启动数据库