汉诺塔递归问题 Java语言描述

Java递归汉诺塔问题

  • 汉诺塔问题:大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。

    在这里,我们开始的时候就只先看第一个柱子上只有3个盘子的情况。
    在这里插入图片描述

    首先,如果我们要将这三个盘子从start柱子移动到to上,所以就要将大盘子上面的两个小盘子(n-1)移动到mid上面,将最底下的大盘子移动到to上,然后我们将mid上面的两个盘子(n-1)移动到to上面,这里,我们如果要将mid上面的两个盘子(n-1)移动到to上面,就要借助start柱子,将mid上面的第一个盘子(n-1)(这里的n-1是没有大盘子时的n-1也就是1)移动到start上面,接着将mid上面的盘子移动到to,最后将start上面的盘子(n=1时)移动到to上面,这样就将开始时候的start上面的盘子移动到了to上面。在这个汉诺塔问题里面,我们编写程序将会演示它执行的过程。
    我们将执行移动的函数写成move,函数需要的参数就是三个盘子的名字和开始柱子上面的盘子数量,这里是3。递归重要的也是它的终止条件,这里的终止条件就是当盘子(n)等于1,这时,我们只需要将这个盘子从当前柱子上面移动到“to”柱子上(这里的to就是盘子要去向的那个柱子,而不是三个柱子中的最后一个)。

import java.util.*;
class H{
    public static void main(String[] args){
        Scanner scanner = new Scanner(System.in);
        System.out.print("请输入有几个盘子:");
        int n = scanner.nextInt();  
        move("a","b","c",n);
    }
    public static void move(String start,String mid,String to,int n){
        if(n == 1){
            System.out.println("移动:"+start+"->"+to);
        }else{
            move(start,to,mid,n-1);		//start上面的n-1个先到达mid,这里的mid就是to
            System.out.println("移动:"+start+"->"+to);
            move(mid,start,to,n-1);		//然后将n-1个盘子从mid移动到to
        }
    }
}

在这里插入图片描述

每当一个move函数自身调用后,它里面参数都要相应的改变,然后从move函数的头部继续从上向下运行,直到n==1时或者继续自身调用(递),接下来继续自上而下运行,当每个move函数运行都n等于1时,然后开始返回上层的move函数(归),直到最初的move函数执行完毕。这样,递归的所有情况将会执行一遍。

- 为什么这里的程序,我们只需要写两边move函数呢?
这是因为,将这种汉诺塔问题划分为“小汉诺塔”问题后,它只需执行三次,如果我们这里只有两个盘子时:
第一次 将start柱子上的第一个盘子移动到mid上面,也就是:

move(start,to,mid,n-1);		//我们将mid当作要到达的柱子,所以要将mid柱子看作为to

第二次 这时,start上面只剩1个盘子了,也就是n=1,所以将start上的大盘子移动到to上

 if(n == 1){
 	System.out.println("移动:"+start+"->"+to);
 	}

第三次 现在,mid上面也是有一个盘子n=1,所以我们将mid移动到最终的to上面

 move(mid,start,to,n-1);
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值