【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】汉诺塔的更多相关文章

  1. BZOJ1019 汉诺塔

    定义f[i][j]为将i柱上的j个盘挪走(按优先级)的步数 p[i][j]为将i柱上的j个盘按优先级最先挪至何处 首先考虑一定p[i][j]!=i 设初始为a柱,p[i][j-1]为b柱 考虑两种情况 ...

  2. BZOJ1019 汉诺塔/洛谷P4285 [SHOI2008]汉诺塔

    汉诺塔(BZOJ) P4285 [SHOI2008]汉诺塔 居然是省选题,还是DP!(我的DP菜得要死,碰见就丢分) 冥思苦想了1h+ \(\to\) ?! 就是普通的hanoi NOI or HNO ...

  3. 【BZOJ1019】[SHOI2008]汉诺塔(数论,搜索)

    [BZOJ1019][SHOI2008]汉诺塔(数论,搜索) 题面 BZOJ 洛谷 题解 首先汉诺塔问题的递推式我们大力猜想一下一定会是形如\(f_i=kf_{i-1}+b\)的形式. 这个鬼玩意不好 ...

  4. bzoj1019 [SHOI2008]汉诺塔

    1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 1030  Solved: 638[Submit][Status] ...

  5. bzoj1019 / P4285 [SHOI2008]汉诺塔

    P4285 [SHOI2008]汉诺塔 递推 题目给出了优先级,那么走法是唯一的. 我们用$0,1,2$代表$A,B,C$三个柱子 设$g[i][x]$为第$x$根柱子上的$i$个盘子,经过演变后最终 ...

  6. bzoj千题计划109:bzoj1019: [SHOI2008]汉诺塔

    http://www.lydsy.com/JudgeOnline/problem.php?id=1019 题目中问步骤数,没说最少 可以大胆猜测移动方案唯一 (真的是唯一但不会证) 设f[i][j] ...

  7. [bzoj1019][SHOI2008]汉诺塔 (动态规划)

    Description 汉诺塔由三根柱子(分别用A B C表示)和n个大小互不相同的空心盘子组成.一开始n个盘子都摞在柱子A上,大的在下面,小的在上面,形成了一个塔状的锥形体. 对汉诺塔的一次合法的操 ...

  8. 【bzoj1019】[SHOI2008]汉诺塔

    1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 1427  Solved: 872[Submit][Status] ...

  9. bzoj1019: [SHOI2008]汉诺塔(动态规划)

    1019: [SHOI2008]汉诺塔 题目:传送门 简要题意: 和经典的汉诺塔问题区别不大,但是题目规定了一个移动时的优先级: 如果当前要从A柱子移动,但是A到C的优先级比A到B的优先级大的话,那就 ...

随机推荐

  1. ruby学习总结04

    1.类和实例的关系 使用[实例.class]查看某个对象属于哪个类 使用[实例.instance_of(类名)]判断该实例是否属于某个类 使用[实例.instance_methods]查看类的所有实例 ...

  2. 【leetcode❤python】 257. Binary Tree Paths

    深度优先搜索 # Definition for a binary tree node.# class TreeNode:#     def __init__(self, x):#         se ...

  3. 【Unity3D游戏开发】Application.systemLanguage无法区分简体中文和繁体中文 (二六)

    游戏发布,语言本地化需要繁体中文和简体中文 iOS8版本之前没问题,iOS9上无法正常识别这两种语言 原因是在iOS9上,Unity通过Application.systemLanguage返回的简体中 ...

  4. SQL设置语言,返回中文”星期几”格式

    SQL中语言表: SELECT * FROM sys.syslanguages   eg: SET LANGUAGE 简体中文 --设置语言 PRINT DATENAME(weekday,GETDAT ...

  5. linux终端下为什么用命令打开软件后,要关闭软件才能继续下一条命令?

    用终端打开chromium浏览器(命令:chromium-browser)的时候发现打开浏览器之后无法继续在终端输入命令,只能关闭浏览器或者在终端按下Ctrl+c,此时系统将退出浏览器并可以继续在终端 ...

  6. 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 ...

  7. ImageMagick远程命令执行工具检测工具

    ImageMagick这个漏洞昨天晚上就出来了,今天才有时间研究一下,今天自己也测试了一下 效果图: ======================= 用lua写了一个检测脚本 print (" ...

  8. SQLserver批量删除空表

    今天需要清理一个很大的数据库,里面表有一堆,而且有很多是空表.想着把数据库弄小点,于是想到一次性删掉所有空表. 废话不多说,上代码. 首先,查处所有的空表. select distinct a.nam ...

  9. Javascript设计模式之匿名函数与闭包

    匿名函数 (function () { var foo = 10; var bar = 2; console.log(foo*bar); })(); // 20 带参数的匿名函数 (function ...

  10. 题目:在泛型为Integer的容器内添加一个字符串.

    这个题目有两种解法,第一种利用反射来解决: //ArrayList<Integer> list = new ArrayList<Integer>(); //在这个泛型为Inte ...