Hanoi

原创 2015年11月21日 20:21:39

 虽然之前就写过,但是都没有现在觉得的明白,拖延癌也是醉了。

 Hanoi问题。

设a, b, c是三个塔座,开始时,a上有n个圆盘,自上而下,由大到小,圆盘编号从1-n,现在要将这些圆盘从a移动到b顺序不变。

移动规则:1.每次只能移动一个。2.任何情况大的不能在小的下面。3.满足1,2情况下,可以在abc上任意移动。

(书上有一个简单的解法,但是并没有算法的实现,去查这个的时候看见这个论坛帖子还不错,贴过来~点我点我点我!!!

下面描述这个简单的算法:假设塔座a,b,c排成一个三角形,a->b->c->a构成一个顺时针循环。在移动圆盘的时候,若是奇数次移动,就把最小的圆盘顺时针移动到下一个塔座;若是偶数次移动,就保持最小的圆盘不动,在其他两个塔中把较小的移到另一个上面。

我还用纸和笔推了一下,亲测成功。)

 说递归算法之前还要说一句分治,什么是分治法?分治法的基本思想就是把一个规模为n的问题分解为k个规模较小的子  问题,这些子问题互相独立且与原问题相同。递归的解子问题,然后将各个子问题的解进行合并就可以得到原问题的  解。

 Hanoi问题的解法就是典型的分治咯。

n个盘子从a->c,中间盘子是b;也就相当于把n-1个盘子从a->b,然后把第n个从a->c,再把剩下的n-1个盘子从b->c就可以实现了。

即hanoi(n, a, c, b) = hanoi(n-1, a, b, c)+move(n, a->c)+hanoi(n-1, b, c, a)

同理n-1个盘子要从a->b,就要把n-2个盘子从a->c,再把第n-1个盘子从a->b,最后再把剩下的n-2个盘子从c->b

 hanoi(n-1, a, b, c) = hanoi(n-2, a, c, b)+move(n-1, a->b)+hanoi(n-2, c, b, a)

。。。。。。就酱紫下去。

n个盘子从a->c的问题变成了n-1个盘子从a->b   

n-1个盘子从a->b的问题就变成了n-2个盘子从a->c

n-2个盘子从a->c的问题就又可以变成n-3个盘子从a->b

最后1个盘子直接移动即可

大问题变成小问题,然后解决。

不知道你懂没懂,反正我懂了。。大笑

落下一句话,移动次数是num = 2^n-1

代码:

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
int cnt;
void hanoi(int n, char a, char b, char c){
    if(n == 1){
        printf("%c->%c\n", a, b);
    }
    else{
        hanoi(n-1, a, c, b);
        printf("%c->%c\n", a, b);
        hanoi(n-1, c, b, a);
    }
}

int main()
{
    int n;
    scanf("%d", &n);
    hanoi(n, 'a', 'b', 'c');
    return 0;
}
运行结果:



hanoi算法数据结构

  • 2013年04月23日 12:37
  • 432B
  • 下载

汉诺塔 Hanoi

  • 2014年02月08日 23:12
  • 23KB
  • 下载

{hanoi塔大集合}hdoj的汉诺塔问题

普通汉诺塔 H(1)=1; H(n)=H(n-1)+1+H(n-1)=2*H(n-1)+1;//将最顶层n-1个移至B柱子,把最大的移至C,再把n-1个移至C 解得通项H(n)=2^n-1; ...

基础的C++程序hanoi

  • 2014年01月13日 17:01
  • 7KB
  • 下载

VB Hanoi问题

  • 2010年06月07日 14:44
  • 40KB
  • 下载

Hanoi塔问题 栈与递归C语言编程实现

Hanoi塔 栈与递归C编程实现 参考书 严蔚敏  数据结构 #include #include #include typedef int ElemType; typedef int ...

hanoi游戏源码MFC编写简单

  • 2010年01月08日 23:40
  • 3.43MB
  • 下载

C++写的Hanoi程序

  • 2007年10月24日 17:24
  • 221KB
  • 下载

noip2007 Hanoi双塔问题 (动态规划,汉诺塔问题,高精乘低精)

A1162. 汉诺双塔 时间限制:1.0s   内存限制:256.0MB   总提交次数:1164   AC次数:360   平均分:51.25 将本题分享到:    ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Hanoi
举报原因:
原因补充:

(最多只允许输入30个字)