【解题报告】 POJ1958 奇怪的汉诺塔
【解题报告】 POJ1958 奇怪的汉诺塔
在这样热浪滚滚的暑假,外面晴空高照,在家里刷刷题不妨是最好的选择
——来自wweiyi语录
题目链接(翻译过的):
https://www.acwing.com/problem/content/98/
题意简述:输出四个塔的汉诺塔分别从1个盘子到12个盘子的最少步数
我们看了题之后,可以知道这道题跟三个塔的汉诺塔一样,用递归,但是我们设先移走i个盘子到第二个塔或第三个塔,然后就转化成三个塔的问题了。
但是问题在于不知道i等于多少,而且直接输出12个值要用递归也会有些慢,所以我们做一下优化,记忆化一下,我们就可以很快的输出了
设三个塔n个盘子的步数为d[n],设四个塔n个盘子的步数为f[n]
动态转移方程如下
其中
所以我们就解决了这道题目
代码如下
1 |
|
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 wweiyiのblog!
评论