[递推]B. 【例题2】奇怪汉诺塔
B
.
【
例
题
2
】
奇
怪
汉
诺
塔
B. 【例题2】奇怪汉诺塔
B.【例题2】奇怪汉诺塔
题目描述
汉诺塔问题,条件如下:
- 这里有
A
A
A、
B
B
B、
C
C
C 和
D
D
D 四座塔。 这里有
n
n
n个圆盘,
n
n
n 的数量是恒定的。
- 每个圆盘的尺寸都不相同。
- 所有的圆盘在开始时都堆叠在塔
A
A
A上,且圆盘尺寸从塔顶到塔底逐渐增大。
- 我们需要将所有的圆盘都从塔
A
A
A 转移到塔
D
D
D 上。
- 每次可以移动一个圆盘,当塔为空塔或者塔顶圆盘尺寸大于被移动圆盘时,可将圆盘移至这座塔上。
- 请你求出将所有圆盘从塔
A
A
A 移动到塔
D
D
D,所需的最小移动次数是多少。
输入格式
没有输入。
输出格式
对于每一个整数
n
(
1
≤
n
≤
12
)
n(1 ≤ n ≤ 12)
n(1≤n≤12),输出一个满足条件的最小移动次数,每个结果占一行。
题目解析
看题目,是汉诺塔,只是常规的三塔变成了四塔.
那么我们就考虑四塔的做法.
首先我们定义
d
i
d_{i}
di为三塔时
n
n
n个盘从
A
A
A塔到
C
C
C塔所需的步数.
那么可以得出(证明略):
d
1
=
1
d_{1} = 1
d1=1
d
i
=
d
i
−
1
∗
2
−
1
(
i
>
1
)
d_{i} = d_{i-1}*2-1~~~~~~~~~~~~~~(i>1)
di=di−1∗2−1 (i>1)
然后我们定义
f
(
i
)
f(i)
f(i)为四塔汉诺塔的最优步数为考虑四塔汉诺塔的算法思想,叫Frame算法:
用四柱汉诺塔算法把
A
A
A柱上部分的
n
−
r
n- r
n−r个碟子通过
C
C
C柱和
D
D
D柱移到
B
B
B柱上(为
f
(
n
−
r
)
f( n- r )
f(n−r)步)。
用三柱汉诺塔经典算法把
A
A
A柱上剩余的
r
r
r个碟子通过
C
C
C柱移到
D
D
D柱上(三塔汉诺塔
r
r
r盘的步数)。
用四柱汉诺塔算法把
B
B
B柱上的
n
−
r
n-r
n−r个碟子通过
A
A
A柱和
C
C
C柱移到
D
D
D柱上(为
f
(
n
−
r
)
f(n-r)
f(n−r)步)。
依据上边规则求出所有
r
(
1
≤
r
≤
n
)
r(1≤r≤n)
r(1≤r≤n)情况下步数
f
(
n
)
f(n)
f(n),取最小值得最终解。
f
[
i
]
=
m
i
n
{
f
[
i
]
2
∗
f
[
j
]
+
d
[
i
−
j
]
f[i] = min \left\{\begin{matrix} & f[i]\\ & 2 * f[j] + d[i - j]\\ \end{matrix}\right.
f[i]=min{f[i]2∗f[j]+d[i−j]
Code
#include <bits/stdc++.h>
#define ll long long
using namespace std;
ll d[305], f[305];
int main ()
{
d[1] = f[1] = 1;
for (int i = 2; i <= 12; ++ i)
d[i] = d[i - 1] * 2 + 1;
for (int i = 2; i <= 12; ++ i)
{
f[i] = 999999999;
for (int j = 1; j <= i; ++ j)
f[i] = min (f[i], 2 * f[j] + d[i - j]);
}
for (int i = 1; i <= 12; ++ i)
printf ("%d\n", f[i]);
return 0;
}
[递推]B. 【例题2】奇怪汉诺塔的更多相关文章
- C++例题2:汉诺塔问题
#include<iostream>#include<stdlib.h>using namespace std;void Hanoi(int n,char A,char B,c ...
- HDU 汉诺塔系列
做了这一系列题,表示对汉诺塔与这一系列递推理解加深了 经典汉诺塔:1,2,...,n表示n个盘子,数字大盘子就大,n个盘子放在第1根柱子上,按照从上到下 从小到大的顺序排放,过程中每次大盘都不能放在小 ...
- 【BZOJ 1019】【SHOI2008】汉诺塔(待定系数法递推)
1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 559 Solved: 341[Submit][Status] ...
- 汉诺塔III 递推题
题目描述: 约19世纪末,在欧州的商店中出售一种智力玩具,在一块铜板上有三根杆,最左边的杆上自上而下.由小到大顺序串着由64个圆盘构成的塔.目的是将最左边杆上的盘全部移到右边的杆上,条件是一次只能移动 ...
- BZOJ 1019 :[SHOI2008]汉诺塔(递推)
好吧蒟蒻还是看题解的 其实看到汉诺塔就该想到是递推了 设f[i][j]表示i个在j杆转移到另一个杆的次数 g[i][j]表示i个在j杆转移到那个杆上 可得 f[i][j]=f[i-1][j]+1+f[ ...
- hdu 1207 汉诺塔II (DP+递推)
汉诺塔II Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submi ...
- Acwing-96-奇怪的汉诺塔(递推)
链接: https://www.acwing.com/problem/content/description/98/ 题意: 汉诺塔问题,条件如下: 1.这里有A.B.C和D四座塔. 2.这里有n个圆 ...
- HDU 1207 汉诺塔II (递推)
经典的汉诺塔问题经常作为一个递归的经典例题存在.可能有人并不知道汉诺塔问题的典故.汉诺塔来源于印度传说的一个故事,上帝创造世界时作了三根金刚石柱子,在一根柱子上从下往上按大小顺序摞着64片黄金圆盘.上 ...
- HDU 1207 汉诺塔II (找规律,递推)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1207 汉诺塔II Time Limit: 2000/1000 MS (Java/Others) ...
随机推荐
- egg.js in action
egg.js in action fullstack https://github.com/eggjs/egg/ cli config router service midlewares HTTP C ...
- Event Bus & Event Emitter
Event Bus & Event Emitter Event Bus https://code.luasoftware.com/tutorials/vuejs/parent-call-chi ...
- Flutter ColorFiltered 将ColorFilter应用于其子级。
ColorFiltered ColorFilter BlendMode Example <summary>main.dart</summary> import 'package ...
- 什么是NGK节点?NGK的节点有什么作用?
从2018年EOS竞选超级节点火爆整个区块链圈,节点和超级节点就成为了热议的话题,时至今日,热度依然不减.节点是项目生态发展的重要组成部分,超级节点对项目的运行.安全更是起着至关重要的作用. 什么 ...
- BGV币与YFI币、YFII币存在着怎样的相关性?
大多数的玩家并没有长期的打算,而是更倾向于关注短期利好的币种.比如最近在圈内赚足眼球的YFI,之所以能够成为明星角色,并非它的技术和平台,而是因为它在短期就创造了86倍的暴涨.YFI币的暴涨在某种程度 ...
- 《Effective Java》总结
导语 <Effective Java>是和<Thinking in java>齐名的java进阶书籍.作者参与了JDK标准库的编写工作,对于此书的学习,让我收获很多.好记性不如 ...
- Ribbon实现负载均衡时 服务提供者注册失败 原因之一
问题描述:提供者注册时总是不用自己配置的server.port 在project structuree中的模块总是自动添加别的模块的文件 那么一定要看看project structure中的langu ...
- 元类、orm
目录 一.内置函数exec 二.元类 1. 什么是元类 2. 元类的作用 3. 创建类的两种方法 4. 怎么自定义创建元类 三.ORM 1. ORM中可能会遇到的问题 2. ORM中元类需要解决的问题 ...
- Prism.WPF -- Prism框架使用(上)
本文参考Prism官方示例 创建Prism项目 将App.xaml中的WPF标准Application替换为PrismApplication,移除StartupUri属性: 将App.xaml.cs中 ...
- 第46天学习打卡(四大函数式接口 Stream流式计算 ForkJoin 异步回调 JMM Volatile)
小结与扩展 池的最大的大小如何去设置! 了解:IO密集型,CPU密集型:(调优) //1.CPU密集型 几核就是几个线程 可以保持效率最高 //2.IO密集型判断你的程序中十分耗IO的线程,只要大于 ...