重新整理数据结构与算法(c#)—— 算法套路分治算法[二十五]
前言
有一个汉罗塔的游戏如下:
汉诺塔:汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。
大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。
大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。
正文
假设有一个盘子:
那么直接从a到c。
假设有两个盘子。
那么小盘子从a到b。
然后大盘子从a-c,小盘子从b-C
3个盘子:
最小的盘子从a->c,然后中盘a-b,然后吧a->b,小盘从c->b,然后吧最大盘放到C上,这时候就放好了一个盘,这时候最大盘已经不用管了,其实就剩下2个盘。然后把小盘放在a,然后中盘b->C,然后小盘a->c。
这时候发现一个规律啊,那就是比如我们又n个盘,放好了一个盘后,其实处理的问题了处理次数是和n-1个盘是一样的。
代码:
static void Main(string[] args)
{
hanoiTower(5,'A','B','C');
Console.Read();
}
public static void hanoiTower(int num, char a, char b, char c)
{
if (num == 1)
{
Console.WriteLine("运动:" + a + "->" + c);
}
else
{
//将num-1个盘从a搬运到b
hanoiTower(num - 1, a, c, b);
//将一个盘搬运到C完成一个盘
Console.WriteLine("运动:" + a + "->" + c);
//当一个盘搬运完毕后,剩下就是处理num-1个盘的问题了,那么此时的b就是原来的a
hanoiTower(num - 1, b, a, c);
}
}
结果:
我现实中折纸试过。