手把手带你用java搞定汉诺塔

 更新时间:2021年08月06日 11:08:28   作者:rampant boy  
这篇文章主要给大家介绍了关于Java青蛙跳台阶问题的解决思路与代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

什么是汉诺塔

汉诺塔问题是一个经典的问题。汉诺塔(Hanoi Tower),又称河内塔,源于印度一个古老传说。

大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。

大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,任何时候,在小圆盘上都不能放大圆盘,且在三根柱子之间一次只能移动一个圆盘。问应该如何操作?

问题剖析

我们假设圆盘数量为n,圆盘初始放在A柱上,最后移到C柱。

n=1

移动方法:A -> C

n=2

在这里插入图片描述

移动方法:A -> B A -> C B -> C

n=3

在这里插入图片描述

移动方法:A -> C A -> B C -> B A -> C B -> A B -> C A -> C

小结

通过这上面三个情况,我们可以知道:

  • 当红色圆盘上面没有其他圆盘的时候,就直接把红色圆盘移到C柱上。
  • 当红色圆盘上面有其他圆盘的时候,先把其他圆盘移到B柱上,然后再将红色圆盘移到C柱上。在把B柱上紫色圆盘上面的其他圆盘移到A柱,接着再将紫色圆盘移到C柱上。然后再次循环。

例如当n=4时,

image-20210805172203810

image-20210805172437620

Java代码实现

public class TestDemo {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        hanoiTower(n,'A','B','C');
    }

    public static void hanoiTower(int n,char A,char B,char C) {
        if(n < 2) {
            move(A,C);
        } else {
            hanoiTower(n - 1,A,C,B);
            move(A,C);
            hanoiTower(n - 1,B,A,C);
        }
    }

    public static void move(char src,char des) {
        System.out.println(src + " -> " + des);
    }
}

例如输入3,结果为:

在这里插入图片描述

代码讲解

move函数

 public static void move(char src,char des) {
    System.out.println(src + " -> " + des);
}

src表示起始圆盘所在的柱子,des表示该圆盘需要移动到的柱子。

hanoiTower函数

public static void hanoiTower(int n,char A,char B,char C) {
    if(n < 2) {
        move(A,C);
    } else {
        hanoiTower(n - 1,A,C,B);
        move(A,C);
        hanoiTower(n - 1,B,A,C);
    }
}

hanoiTower的第一个参数,代表还有n个圆盘需要移动,A代表起始圆盘所在的柱子,C代表该圆盘所要移动到的柱子,B代表圆盘移动时所经历的中间柱子。

例如n=3时,先需要把上面两个圆盘经过一系列的移动,全部移动到B柱上,所以就得调用hanoiTower(2,A,C,B);然后再将A柱上唯一的一个圆盘移动到C柱上,所以调用move(A,C);然后再将B柱上除最下面的圆盘以外的圆盘移动到A柱上,然后再重复这个步骤,直到所有的圆盘都移动到C柱为止。

所以调用hanoiTower(2,B,A,C);

附:C语言实现汉诺塔

#include<stdio.h>

void Move(char src, char des)
{
	printf("%c -> %c", src, des);
	printf("\n");
}

void HanoiTower(int n, char A, char B, char C)
{
	if (n == 1)
	{
		Move(A, C);
	}
	else
	{
		HanoiTower(n - 1, A, C, B);
		Move(A, C);
		HanoiTower(n - 1, B, A, C);
	}
}

int main()
{
	int n = 0;
	scanf("%d", &n);
	HanoiTower(n, 'A', 'B', 'C');
	return 0;
}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

相关文章

  • Java并发编程进阶之线程控制篇

    Java并发编程进阶之线程控制篇

    在使用Java实际编程中,多线程可以说是无所不在,凡是需要并发执行的都可以用到它,一个应用程序中不用多线程将会是很糟糕的事情,所以掌握线程以及它的控制操作是非常重要的。通过本篇文章来今天带大家一文掌握线程控制操作,感谢您的观看
    2022-07-07
  • Java 中的 String对象为什么是不可变的

    Java 中的 String对象为什么是不可变的

    String对象是不可变的,但这仅意味着你无法通过调用它的公有方法来改变它的值。本文给大家介绍java中的string对象为什么是不可变的,需要的朋友一起了解了解吧
    2015-10-10
  • Java毕业设计实战之食品溯源系统的实现

    Java毕业设计实战之食品溯源系统的实现

    这是一个使用了java+Springboot+Maven+mybatis+Vue+mysql+wd开发的食品溯源系统,是一个毕业设计的实战练习,具有食品溯源该有的所有功能,感兴趣的朋友快来看看吧
    2022-01-01
  • fastjson对JSONObject中的指定字段重新赋值的实现

    fastjson对JSONObject中的指定字段重新赋值的实现

    这篇文章主要介绍了fastjson对JSONObject中的指定字段重新赋值的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • java实现拼图游戏

    java实现拼图游戏

    这篇文章主要为大家详细介绍了java实现拼图游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • springboot中spring.profiles.include的妙用分享

    springboot中spring.profiles.include的妙用分享

    这篇文章主要介绍了springboot中spring.profiles.include的妙用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • 一招教你使用Java执行groovy脚本的两种方式

    一招教你使用Java执行groovy脚本的两种方式

    本文主要介绍了一招教你使用Java执行groovy脚本的两种方式,一种是通过脚本引擎ScriptEngine提供的eval(String)方法执行脚本内容,一种是执行groovy脚本,感兴趣的可以了解一下
    2023-09-09
  • 简单了解java标识符的作用和命名规则

    简单了解java标识符的作用和命名规则

    这篇文章主要介绍了简单了解java标识符的作用和命名规则,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01
  • Java实现HTTP请求的4种方式总结

    Java实现HTTP请求的4种方式总结

    这篇文章主要给大家介绍了关于Java实现HTTP请求的4种方式,在java开发中,经常遇到需要调用第三方提供的接口服务的需求,文中给出了详细的代码示例,需要的朋友可以参考下
    2023-08-08
  • Java图片处理之获取gif图一帧图片的两种方法

    Java图片处理之获取gif图一帧图片的两种方法

    这篇文章主要给大家介绍了关于Java图片处理之获取gif图一帧图片的两种方法,分别是利用Java原生代码和使用im4java调用ImageMagick来实现,两种方法都给出来示例代码供大家参考学习,需要的朋友们下面来一起看看吧。
    2017-10-10

最新评论