【bzoj1019】汉诺塔
【bzoj1019】汉诺塔
题意
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1019
分析
思路1:待定系数+解方程
设\(f[n]\)为\(n\)个盘子的答案。
看似这么简单的设数方式!
我们大胆地猜想,它存在线性的递推式!
不难想到先模拟出前几项,然而用待定系数+解方程解出递推式(然而我最初并没有想到...),然后直接递推就OK了。
%%WJMZBMR
思路2:递推
设\(f[x][i]\)表示第\(x\)根柱子上有\(i\)个盘子的最少转移次数,以及转移到的柱子为\(g[x][i]\)
奠基:
\(f[x][1]\)根据优先级来求
\(g[x][1]=1\)
转移:当前已知\(f[?][i-1]\)和\(g[?][i-1]\)的答案,考虑求解\(f[x][i]\)和\(g[x][i]\)
设\(y=g[x][i-1],k=(1+2+3)-(x+y)\),即没有用的哪根柱子。第一步必然是将\(x\)的\(i-1\)个移到\(y\),接下来需要分类讨论。
①当\(g[y][i-1]=k\)时,我们选择这样的策略:
- 将\(x\)的\(i-1\)个移到\(y\)
- 将\(x\)的最后一个移到\(k\)
- 将\(y\)的\(i-1\)个移到\(k\)
得到:
\(f[x][i]=f[x][i-1]+1+f[y][i-1]\)
\(g[x][i]=k\)
②当\(g[y][i-1]=x\)时,我们选择这样的策略:
- 将\(x\)的\(i-1\)个移到\(y\)
- 将\(x\)的最后一个移到\(k\)
- 将\(y\)的\(i-1\)个移到\(x\)
- 将\(k\)的唯一一个移到\(y\)
- 将\(x\)的\(i-1\)个移到\(y\)
得到:
\(f[x][i]=f[x][i-1]+1+f[y][i-1]+1+f[x][i-1]\)
\(g[x][i]=y\)
为什么这样是正确的?
其实并不知道......
但好像汉诺塔一类的问题都是这样贪心就可以了。
小结
(1)汉诺塔一类的问题
知结论。
会递推。
会递归。
(2)一类待定系数法解决的问题
对于求\(f(n)\)这类的问题,我们可以大胆地猜想:它是线性的。
然后求解前几项,再解出来,然后就很容易了,最多结合个什么矩阵乘法之类的。
有时候不是线性的也可以解决啊。
例如\(f[i]=af[i-1]^2+bf[i-1]+c\),依然可以使用待定系数求解。
类似的问题:bzoj1002轮状病毒
【bzoj1019】汉诺塔的更多相关文章
- BZOJ1019 汉诺塔
定义f[i][j]为将i柱上的j个盘挪走(按优先级)的步数 p[i][j]为将i柱上的j个盘按优先级最先挪至何处 首先考虑一定p[i][j]!=i 设初始为a柱,p[i][j-1]为b柱 考虑两种情况 ...
- BZOJ1019 汉诺塔/洛谷P4285 [SHOI2008]汉诺塔
汉诺塔(BZOJ) P4285 [SHOI2008]汉诺塔 居然是省选题,还是DP!(我的DP菜得要死,碰见就丢分) 冥思苦想了1h+ \(\to\) ?! 就是普通的hanoi NOI or HNO ...
- 【BZOJ1019】[SHOI2008]汉诺塔(数论,搜索)
[BZOJ1019][SHOI2008]汉诺塔(数论,搜索) 题面 BZOJ 洛谷 题解 首先汉诺塔问题的递推式我们大力猜想一下一定会是形如\(f_i=kf_{i-1}+b\)的形式. 这个鬼玩意不好 ...
- bzoj1019 [SHOI2008]汉诺塔
1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 1030 Solved: 638[Submit][Status] ...
- bzoj1019 / P4285 [SHOI2008]汉诺塔
P4285 [SHOI2008]汉诺塔 递推 题目给出了优先级,那么走法是唯一的. 我们用$0,1,2$代表$A,B,C$三个柱子 设$g[i][x]$为第$x$根柱子上的$i$个盘子,经过演变后最终 ...
- bzoj千题计划109:bzoj1019: [SHOI2008]汉诺塔
http://www.lydsy.com/JudgeOnline/problem.php?id=1019 题目中问步骤数,没说最少 可以大胆猜测移动方案唯一 (真的是唯一但不会证) 设f[i][j] ...
- [bzoj1019][SHOI2008]汉诺塔 (动态规划)
Description 汉诺塔由三根柱子(分别用A B C表示)和n个大小互不相同的空心盘子组成.一开始n个盘子都摞在柱子A上,大的在下面,小的在上面,形成了一个塔状的锥形体. 对汉诺塔的一次合法的操 ...
- 【bzoj1019】[SHOI2008]汉诺塔
1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 1427 Solved: 872[Submit][Status] ...
- bzoj1019: [SHOI2008]汉诺塔(动态规划)
1019: [SHOI2008]汉诺塔 题目:传送门 简要题意: 和经典的汉诺塔问题区别不大,但是题目规定了一个移动时的优先级: 如果当前要从A柱子移动,但是A到C的优先级比A到B的优先级大的话,那就 ...
随机推荐
- ruby学习总结04
1.类和实例的关系 使用[实例.class]查看某个对象属于哪个类 使用[实例.instance_of(类名)]判断该实例是否属于某个类 使用[实例.instance_methods]查看类的所有实例 ...
- 【leetcode❤python】 257. Binary Tree Paths
深度优先搜索 # Definition for a binary tree node.# class TreeNode:# def __init__(self, x):# se ...
- 【Unity3D游戏开发】Application.systemLanguage无法区分简体中文和繁体中文 (二六)
游戏发布,语言本地化需要繁体中文和简体中文 iOS8版本之前没问题,iOS9上无法正常识别这两种语言 原因是在iOS9上,Unity通过Application.systemLanguage返回的简体中 ...
- SQL设置语言,返回中文”星期几”格式
SQL中语言表: SELECT * FROM sys.syslanguages eg: SET LANGUAGE 简体中文 --设置语言 PRINT DATENAME(weekday,GETDAT ...
- linux终端下为什么用命令打开软件后,要关闭软件才能继续下一条命令?
用终端打开chromium浏览器(命令:chromium-browser)的时候发现打开浏览器之后无法继续在终端输入命令,只能关闭浏览器或者在终端按下Ctrl+c,此时系统将退出浏览器并可以继续在终端 ...
- Create Hierarchical Tree To Control Records In Oracle Forms
Download Source Code Providing an example form for creating hierarchical trees in Oracle Forms to co ...
- ImageMagick远程命令执行工具检测工具
ImageMagick这个漏洞昨天晚上就出来了,今天才有时间研究一下,今天自己也测试了一下 效果图: ======================= 用lua写了一个检测脚本 print (" ...
- SQLserver批量删除空表
今天需要清理一个很大的数据库,里面表有一堆,而且有很多是空表.想着把数据库弄小点,于是想到一次性删掉所有空表. 废话不多说,上代码. 首先,查处所有的空表. select distinct a.nam ...
- Javascript设计模式之匿名函数与闭包
匿名函数 (function () { var foo = 10; var bar = 2; console.log(foo*bar); })(); // 20 带参数的匿名函数 (function ...
- 题目:在泛型为Integer的容器内添加一个字符串.
这个题目有两种解法,第一种利用反射来解决: //ArrayList<Integer> list = new ArrayList<Integer>(); //在这个泛型为Inte ...