• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Java > java 汉诺塔详解及实现代码

java 汉诺塔详解及实现代码

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了汉诺塔java代码,java汉诺塔递归算法,java汉诺塔问题,java汉诺塔算法,java汉诺塔游戏等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

java 汉诺塔详解及实现代码

实现效果图

打印的方法在 moveTheTopOne() 方法中被调用,调用该方法前打印出移动的方向--从X号塔往Y号塔

汉诺塔要求:将第一座塔上的所有盘子,借助第二座塔,全部搬运到第三座塔上。

规则:一次只能搬运一个盘子,不准将大盘子落在小盘子上。

 汉诺塔实现代码:

public class NewHanoi {
  public static int tiers = 4; // tiers 层数
  private static List<String> pagoda1 = new ArrayList<String>(); // 静态指针
  private static List<String> pagoda2 = new ArrayList<String>();

  private static List<String> pagoda3 = new ArrayList<String>(); 

  // 映射,用来确定并打印塔的序号(使用角标),也可以使用 Map

  private static List[] mapping = {pagoda1, pagoda2, pagoda3};


  public static void main(String[] args) { 
    preparePagoda(pagoda1, tiers); 
    System.out.println("初始状态:");
    printPagodas(); 
    hanoi(tiers, pagoda1, pagoda2, pagoda3); 
    System.out.println("最后结果:");
    printPagodas();
  }
  // --准备盘子(添加-字符串) (源塔)上
  private static void preparePagoda(List<String> srcPagoda, int tiers) {

    // 用于拼装塔层的容器
    StringBuilder builder = new StringBuilder();

    // 源塔的每一层加盘子,从底层开始, i ‘代表'盘子的直径大小,等于组成盘子的"^"个数
    for(int i = tiers; i > 0; i--){      

      // 每一层由 2*tiers-1 个格子组成,代表盘子大小的"^"格子由空格隔开
      for(int k = 0; k < tiers - i; k++) builder.append(" "); // 盘子左边的空格,数量为 [2*tiers-1-(2*i-1)]/2 = tiers-i, 右边相同
      for(int j = 1; j <= 2*i-1; j++){    // 盘子所占格数
        if(j % 2 == 1) builder.append("^"); // 间隔摆放

        else builder.append(" ");
      }
      for(int k = 0; k < tiers - i; k++) builder.append(" "); // 盘子右边的空格

      srcPagoda.add(builder.toString());  // 添加到塔上
      builder.delete(0, builder.length()); // 下一循环前清空容器
    }
  }
  // --打印塔的现状

  private static void printPagodas(){

     // 打印层数为三座塔-现状的最大高度
    int len = Math.max(pagoda1.size(), Math.max(pagoda2.size(), pagoda3.size()));
    // 用于-塔的空层显示

    StringBuilder spaces = new StringBuilder(); 
    spaces.append("-");  // --添加塔的左外框
    for(int i = 0; i < 2*tiers-1; i++) spaces.append(" "); // 空层显示用空格
    spaces.append("-\t"); // --添加塔的右外框和塔间间隔    

    

    for(int i = len - 1; i >= 0; i--){ // 从顶层开始      

      // 三座塔同一水平面的塔层放在同一行显示
      // 当某个塔不存在此层时,List.get(index)会抛角标越界异常,使用try-catch处理:此层显示一层空格 
      try { System.out.print("-" + pagoda1.get(i) + "-\t");
      } catch (Exception e1) { System.out.print(spaces);
      }
      try { System.out.print("-" + pagoda2.get(i) + "-\t");
      } catch (Exception e) { System.out.print(spaces);
      }
      try { System.out.print("-" + pagoda3.get(i) + "-\t");
      } catch (Exception e) { System.out.print(spaces);
      }
      System.out.print("\r\n");
    }
  }
  // 这个方法(递归的核心方法)从指定的源塔上移动-指定数量的盘子-到指定的目标塔上

  public static void hanoi(int moveNum, List<String> from, List<String> middle, List<String> to) {
    if(moveNum == 1){ // 递归到移动一个盘子时,使用 move 方法 
      moveTheTopOne(from, to);
      return;
    }

    // 将实现分为三步,一,将源塔底盘上方的所有盘子移至中间塔(递归);二,将底盘移到目标塔;三,将中间塔上的所有盘子移到目标塔上(递归)。
    hanoi(moveNum - 1, from, to, middle);
    moveTheTopOne(from, to);
    hanoi(moveNum - 1, middle, from, to);
  }
  // 方法的名字就是他的作用
  private static void moveTheTopOne(List<String> from, List<String> to) {
    String theTopOne = from.remove(from.size() - 1);
    to.add(theTopOne);

    // 打印图形,每移动一下,打印图形显示
    System.out.println("********** print ***********\r\n");
    // 确定塔的序号
    int fromNum = 0, toNum = 0;
    for (int i = 0; i < mapping.length; i++) { // 遍历塔的数组
  
      if (mapping[i] == from) {
         fromNum = i+1;
      }
      if (mapping[i] == to) {
         toNum = i+1;
      }
    }
    System.out.println("从 " + fromNum + " 号塔往 " + toNum + " 号塔\r\n");

    printPagodas(); // 打印图形
  }
}

</div>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • java 汉诺塔详解及实现代码
  • java 实现汉诺塔详解及实现代码
  • java 汉诺塔详解及实现代码
  • java 实现汉诺塔详解及实现代码

相关文章

  • 2017-05-28java连接数据库(代码分享)
  • 2017-05-28mybatis分页效果实现代码
  • 2017-05-28SpringMVC接收页面表单参数
  • 2017-05-28Spring Boot(四)之使用JWT和Spring Security保护REST API
  • 2017-05-28Spring2.5.6开发环境搭建图文教程
  • 2017-05-28SpringBoot远程访问redis服务器问题剖析
  • 2017-05-28Android 应用按返回键退向后台运行实例代码
  • 2017-05-28详解Java虚拟机管理的内存运行时数据区域
  • 2017-05-28Spring 4 支持的 Java 8 特性
  • 2017-05-28Spring Boot 启动加载数据 CommandLineRunner的使用

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • java 值Document解析xml详细介绍
    • SWT(JFace) FTP客户端实现
    • 二维码生成Java实现代码
    • Java网络通信基础编程(必看篇)
    • 详解Spring-Boot集成Spring session并存入redis
    • Java String 和StringBuffer的详解及区别
    • 深入理解Java嵌套类和内部类
    • SSM框架+Plupload实现分块上传大文件示例
    • Java序列化和反序列化_动力节点Java学院整理
    • servlet监听实现统计在线人数功能 附源码下载

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有