奇怪的汉诺塔

简介: 笔记

96. 奇怪的汉诺塔 - AcWing题库


题意

汉诺塔问题,条件如下:


1、这里有 A、B、C 和 D 四座塔。


2、这里有 n 个圆盘,n 的数量是恒定的。


3、每个圆盘的尺寸都不相同。


4、所有的圆盘在开始时都堆叠在塔 A 上,且圆盘尺寸从塔顶到塔底逐渐增大。


5、我们需要将所有的圆盘都从塔 A 转移到塔 D 上。


6、每次可以移动一个圆盘,当塔为空塔或者塔顶圆盘尺寸大于被移动圆盘时,可将圆盘移至这座塔上。


请你求出将所有圆盘从塔 A 移动到塔 D,所需的最小移动次数是多少。


100.png

                                             汉诺塔参考模型


思路

首先我们要明确这题在问什么,用一句话概括上面的题意:将n层汉诺塔,通过两根柱子的辅助,移动到第四根柱子上


设 g[n] 为 n 层汉诺塔按照题意需要移动的最小步数,g[n] 可以怎么求呢?


先取最上面的 i 层,通过 C、D 两个柱子 移动到 B 柱上,再把剩下的 n - i 层 通过 C 柱 移动到 D 柱,最后把 B 柱上的 i 层 通过 A、C两个柱子移动到 D 柱,每个过程的最小值加在一起就是最小步数。


上述过程中,有两个过程为 借助两个柱子,从一个柱子移动到另一个柱子 这即为我们要求的 g 数组,还有一个过程为 借助一个柱子,从一个柱子移动到另一个柱子 这就是我们熟悉的 三柱汉诺塔问题。


对于每一个 n 枚举 i 找到最小值 即为答案


代码

#include<bits/stdc++.h>
// #define int long long
#define INF 0x3f3f3f3f
#define mod 1000000007
#define MOD 998244353
#define rep(i, st, ed) for (int (i) = (st); (i) <= (ed);++(i))
#define pre(i, ed, st) for (int (i) = (ed); (i) >= (st);--(i))
using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int, int> PII;
template<typename T> inline T gcd(T a, T b) { return b ? gcd(b, a % b) : a; }
template<typename T> inline T lowbit(T x) { return x & -x; }
const int N = 1e3 + 10;
int f[20], g[20];
int n = 12;
void solve() {
  f[1] = 1;
  for (int i = 2; i <= n; ++i) {
    f[i] = 2 * f[i - 1] + 1;
  }
  memset(g, 0x3f, sizeof g);
  g[1] = 1;
  for (int i = 1; i <= n; ++i) {
    for (int j = 0; j <= i; ++j) {
      g[i] = min(g[i], 2 * g[j] + f[i - j]);
    }
  }
  for (int i = 1; i <= 12; ++i)printf("%d\n", g[i]);
}
signed main() {
  // int t; cin >> t;
  // while (t--)
    solve();
  return 0;
}
in() {
// int t; cin >> t;
// while (t–)
solve();
return 0;
}
目录
相关文章
|
2月前
|
算法 测试技术 C++
【动态规划】【记忆化搜索】【C++算法】664. 奇怪的打印机
【动态规划】【记忆化搜索】【C++算法】664. 奇怪的打印机
|
7月前
|
C++
10.【C++猜数字游戏(看一眼就会)】
10.【C++猜数字游戏(看一眼就会)】
88 0
|
10月前
|
C语言
C真的不难学,不信就看下我关于循环的理解
C真的不难学,不信就看下我关于循环的理解
|
10月前
洛谷P1135 奇怪的电梯——广搜
洛谷P1135 奇怪的电梯——广搜
72 0
|
10月前
|
算法 Python
转:最大公约数算法很无聊吗?一个轻松方法(辗转相除法)3行代码搞定
最大公约数算法不是很无聊,计算最大公约数是数学中一个重要的概念,可以用于判断两个数是否互质、求分数的约分等,在很多领域都有广泛的应用。辗转相除法3行代码搞定。
48 0
|
11月前
|
算法
【C】快速求最大公约数的三种办法
最大公因数,也称最大公约数、最大公因子,指两个或多个整数共有约数中最大的一个。a,b的最大公约数记为(a,b),同样的,a,b,c的最大公约数记为(a,b,c),多个整数的最大公约数也有同样的记号。求最大公约数有多种方法,常见的有质因数分解法、短除法、辗转相除法、更相减损法。与最大公约数相对应的概念是最小公倍数,a,b的最小公倍数记为[a,b]。 为大家带来找最大公约数的两种办法,1.暴力求解法,2.辗转相除法,3,更相减损法
|
11月前
|
Java C语言
C语言实现双轴快排—例题leetcode 912(手敲
C语言实现双轴快排—例题leetcode 912(手敲
|
缓存 算法 Java
|
算法
蓝桥杯 算法 猴子吃包子、 查找整数
蓝桥杯 算法 猴子吃包子、 查找整数