返回顶部
首页 > 资讯 > 后端开发 > Python >JavaSE求解汉诺塔问题的示例代码
  • 772
分享到

JavaSE求解汉诺塔问题的示例代码

2024-04-02 19:04:59 772人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录1.问题描述2.画图分析3.问题讲解  4.代码实现1.问题描述 汉诺塔问题是一个经典的问题。汉诺塔(Hanoi Tower),又称河内塔,源于印度一个古老传说。 大梵

1.问题描述

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

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

大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。

并且规定,任何时候,在小圆盘上都不能放大圆盘,且在三根柱子之间一次只能移动一个圆盘。 问应该如何操作? 

2.画图分析

一个圆盘的情况:移动前

移动后

1个盘子:A直接移动到C

二个圆盘的情况:移动前

移动后

2个圆盘:A->B  A->C B->C

三个圆盘的情况:移动前

移动后

三个圆盘:A->C A->B C->B A->C B->A  B->C A-C

3.问题讲解  

当有3个盘子的时候,你就会发现一个问题,你肯定是要先将上面的两个盘子移动到B柱,再把最底下的一个盘子移动到C柱,最后再把B柱的盘子移动到C柱。4个盘子的话也是一样,要先将上面的3个盘子移动到B柱,在把最底下的一个盘子移动到C柱,最后再把B柱的盘子移动到C柱。这样我们就有了一个思路,不管多少个盘子,都要先将n - 1个盘子移动到B柱,最底下的一个盘子移动到C柱,最后再把B柱的盘子移动到C柱。

我们先来看一下规律:

1个盘子:A->C       1次

2个盘子:A->B  A->C B->C      3次

3个盘子:A->C A->B C->B A->C B->A  B->C A-C   7次

这样你就能看出移动的次数其实就是2^n - 1(n是盘子的数量)

4.代码实现

ublic class TestDemo {
    //首先要写个模拟鼠标移动过程的函数,我们要打印出移动的全部过程
    //这个move函数做到的就是从1位置移动到2位置,有可能是A->B,A->C,C-B......等各种可能
    public static void move(char pos1,char pos2){//所以说这里只需要传对应的位置就可以了
        System.out.print(pos1+"->"+pos2+" ");//pos1移动到pos2
    }
 
    
    public static void haNIO(int n,char pos1,char pos2,char pos3){
        if(n == 1){
            move(pos1,pos3);//如果只有一个盘子那就从A柱挪到C柱上
        }else{
            hanio(n-1,pos1,pos3,pos2);//这里是把n-1个盘子从A柱借助C柱移动到B柱
            move(pos1,pos3);//底下剩下的最后一个盘子从A柱移动到C柱
            hanio(n-1,pos2,pos1,pos3);//这里是把n-1个盘子从B柱借助A柱移动到C柱
 
        }
 
 
    }
    public static void main(String[] args) {
        hanio(1,'A','B','C');//一开始我们的汉诺塔要规定一下,我们第一次给它传过去的位置
        System.out.println();
        hanio(2,'A','B','C');
        System.out.println();
        hanio(3,'A','B','C');
        System.out.println();
    }
 
 
 
 
}

打印结果:

到此这篇关于Java SE求解汉诺塔问题的示例代码的文章就介绍到这了,更多相关Java汉诺塔问题内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JavaSE求解汉诺塔问题的示例代码

本文链接: https://lsjlt.com/news/142481.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaSE求解汉诺塔问题的示例代码
    目录1.问题描述2.画图分析3.问题讲解  4.代码实现1.问题描述 汉诺塔问题是一个经典的问题。汉诺塔(Hanoi Tower),又称河内塔,源于印度一个古老传说。 大梵...
    99+
    2024-04-02
  • JavaSE递归求解汉诺塔问题的思路与方法
    目录1. 汉诺塔的介绍和玩法2. 汉诺塔问题的思路3. 用递归的代码实现 总结1. 汉诺塔的介绍和玩法 汉诺塔(Tower of Hanoi),又称河内塔,是一个源于印度古...
    99+
    2022-11-13
    javase递归求解汉诺塔 用递归求解汉诺塔问题 递归实现汉诺塔问题java
  • Java SE如何求解汉诺塔问题
    这篇文章主要介绍了Java SE如何求解汉诺塔问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.问题描述汉诺塔问题是一个经典的问题。汉诺塔(Hanoi Towe...
    99+
    2023-06-29
  • Java编程用栈来求解汉诺塔问题的代码实例(非递归)
    【题目】   汉诺塔问题比较经典,这里修改一下游戏规则:现在限制不能从最左侧的塔直接移动到最右侧,也不能从最右侧直接移动到最左侧,而是必须经过中间。求当塔有N层的时候,打印最优移动过程和最优移动总步数。【解答】   上一篇用的是递归的方法解...
    99+
    2023-05-31
    java ava
  • 使用Python实现汉诺塔问题示例
    目录前言1.先谈一下什么是递归?2.简而言之就是:3.过程为:4.递归的关键是:汉诺塔问题1.问题描述2.问题分析 递归的过程:3.代码(Python)4.结果展示前言 汉诺塔问题是...
    99+
    2023-05-17
    Python 实现 Python 汉诺塔问题
  • 用turtle库显示汉诺塔问题的过程
    一、什么是汉诺塔问题?    一座汉诺塔,塔内有3个座A、B、C,A座上有n个盘子,盘子大小不等,大的在下,小的在上,如图所示。把这n个盘子从A座移到C座,但每次只能移动一个盘子,并且自移动过程中,3个座上的盘子始终保持大盘在下,小盘在...
    99+
    2023-01-31
    过程 汉诺 turtle
  • java 汉诺塔详解及实现代码
    java 汉诺塔详解及实现代码实现效果图打印的方法在 moveTheTopOne() 方法中被调用,调用该方法前打印出移动的方向--从X号塔往Y号塔汉诺塔要求:将第一座塔上的所有盘子,借助第二座塔,全部搬运到第三座塔上。规则:一次只能搬运一...
    99+
    2023-05-31
    汉诺塔 java ava
  • c语言汉诺塔问题怎么解决
    解决汉诺塔问题的常见方法是使用递归。以下是使用递归解决C语言汉诺塔问题的示例代码:```c#include void hanoi(i...
    99+
    2023-10-07
    c语言
  • java 实现汉诺塔详解及实现代码
    java 实现汉诺塔详解及实现代码汉诺塔问题:有三根柱子A,B,C,其中A上面有n个圆盘,从上至下圆盘逐渐增大,每次只能移动一个圆盘,并且规定大的圆盘不能叠放在小的圆盘上面,现在想要把A上面的n个圆盘全部都移动到C上面,输出移动的总步数以及...
    99+
    2023-05-31
    java 汉诺塔 ava
  • C#利用递归算法解决汉诺塔问题
    目录一、什么是递归二、汉诺塔问题1.汉诺塔的故事2.解决思路3.怎么解决汉诺塔问题4.具体代码实现三、完整代码一、什么是递归 方法调用自己的行为就是递归,递归必须要有终止条件,不然它...
    99+
    2024-04-02
  • Java用递归方法解决汉诺塔问题详解
    目录前言一、问题描述二、问题分析三、解决方案四、示例前言 博主之前有写过关于递归问题的思维模式: 递归的思路 下面将用这种思维模式来求解经典汉诺塔问题。 一、问题描述 汉诺塔(又称河...
    99+
    2024-04-02
  • java基于递归算法实现汉诺塔问题实例
    本文实例讲述了java基于递归算法实现汉诺塔问题。分享给大家供大家参考,具体如下:package test;import java.util.List;import java.util.ArrayList;import java.util....
    99+
    2023-05-31
    java 递归算法 汉诺塔
  • Java基于栈方式如何解决汉诺塔问题
    这篇文章主要介绍了Java基于栈方式如何解决汉诺塔问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体如下:public class StackHano...
    99+
    2023-05-30
    java
  • JavaScript中递归函数解“汉诺塔”算法的示例分析
    小编给大家分享一下JavaScript中递归函数解“汉诺塔”算法的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!“汉诺塔...
    99+
    2024-04-02
  • C#怎么利用递归算法解决汉诺塔问题
    本篇内容介绍了“C#怎么利用递归算法解决汉诺塔问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、什么是递归方法调用自己的行为就是递归,递...
    99+
    2023-06-30
  • C语言递归函数与汉诺塔问题怎么解决
    今天小编给大家分享一下C语言递归函数与汉诺塔问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。递归函数直接或者间接调...
    99+
    2023-07-02
  • C语言递归函数与汉诺塔问题简明理解
    目录递归函数Hanio(汉诺塔)问题递归函数 直接或者间接调用函数本身。“自己调用自己” 什么情况下面可以使用递归呢 解决一个问题时,解决思路化成与问题本身类...
    99+
    2024-04-02
  • Java手把手必会的实例汉诺塔讲解练习
    最适合菜鸟的汉诺塔讲解 问题引入 汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘...
    99+
    2024-04-02
  • Java通过递归算法解决迷宫与汉诺塔及八皇后问题
    目录1.递归的重要规则2.递归的三个案例1.老鼠出迷宫2.汉诺塔3.八皇后1.递归的重要规则 在执行一个方法时,就创建一个新的受保护的独立空间(栈空间)。方法的局部变量时独立的,不会...
    99+
    2024-04-02
  • Java背包问题求解实例代码
    背包问题主要是指一个给定容量的背包、若干具有一定价值和重量的物品,如何选择物品放入背包使物品的价值最大。其中又分01背包和无限背包,这里主要讨论01背包,即每个物品最多放一个。而无限背包可以转化为01背包。先说一下算法的主要思想,利用动态规...
    99+
    2023-05-30
    java 背包问题 ava
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作