1、增加计时功能,显示用户完成移动盘子所花费的时间 2、用户可以设置最大和最小盘子的大小 3、用户可以选择播放和暂停背景音乐 4、用户可以设置盘子的数目 5、用户可以设置盘子的颜色以及背景的颜色 6、用户可以将自动移动盘子的文本信息保存到文件 在原有代码上增加,增加的新代码要注释

import java.awt.*; import java.awt.event.*; import javax.swing.*; public class AutoMoveDisc extends JDialog implements ActionListener{     int amountOfDisc=3;     TowerPoint [] pointA,pointB,pointC;     char [] towerName;     Container con;     StringBuffer moveStep;     JTextArea showStep;     JButton bStart,bStop,bContinue,bClose;     Timer time;     int i=0,number=0;     AutoMoveDisc(Container con){         setModal(true);         setTitle("自动演示搬盘子过程");         this.con=con;         moveStep=new StringBuffer();         time=new Timer(1000,this);         time.setInitialDelay(10);         showStep=new JTextArea(10,12);         bStart=new JButton("演示");         bStop=new JButton("暂停");         bContinue=new JButton("继续");         bClose=new JButton("关闭");         bStart.addActionListener(this);         bStop.addActionListener(this);         bContinue.addActionListener(this);         bClose.addActionListener(this);         JPanel south=new JPanel();         south.setLayout(new FlowLayout());         south.add(bStart);         south.add(bStop);         south.add(bContinue);         south.add(bClose);         add(new JScrollPane(showStep),BorderLayout.CENTER);         add(south,BorderLayout.SOUTH);         setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE);         towerName=new char[3];         addWindowListener(new WindowAdapter(){                            public void windowClosing(WindowEvent e){                               time.stop();                               setVisible(false);                            }                          });     }     public void setPointA(TowerPoint [] pointA){         this.pointA=pointA;     }     public void setPointB(TowerPoint [] pointB){         this.pointB=pointB;     }     public void setPointC(TowerPoint [] pointC){         this.pointC=pointC;     }     public void setTowerName(char name[]){          if(name[0]==name[1]||name[0]==name[2]||name[1]==name[2]){            towerName[0]='A';            towerName[1]='B';            towerName[2]='C';          }          else             towerName=name;     }     public void setAmountOfDisc(int n){          amountOfDisc=n;     }    public void actionPerformed(ActionEvent e) {       if(e.getSource()==time){             number++;             char cStart,cEnd;             if(i<=moveStep.length()-2){               cStart=moveStep.charAt(i);               cEnd=moveStep.charAt(i+1);               showStep.append("("+number+")从"+cStart+"座搬一个盘子到"+cEnd+"座\n");               autoMoveDisc(cStart,cEnd);             }             i=i+2;             if(i>=moveStep.length()-1){                 time.stop();             }        }       else if(e.getSource()==bStart){            if(moveStep.length()==0){              if(time.isRunning()==false){                  i=0;                  moveStep=new StringBuffer();                  setMoveStep(amountOfDisc,towerName[0],towerName[1],towerName[2]);                  number=0;                  time.start();                 }            }       }       else if(e.getSource()==bStop){            if(time.isRunning()==true)                 time.stop();          }       else if(e.getSource()==bContinue){            if(time.isRunning()==false)                 time.restart();          }       else if(e.getSource()==bClose){            time.stop();            setVisible(false);         }     }    private void setMoveStep(int amountOfDisc,char one,char two,char three){       if(amountOfDisc==1){              moveStep.append(one);              moveStep.append(three);         }       else{              setMoveStep(amountOfDisc-1,one,three,two);              moveStep.append(one);              moveStep.append(three);              setMoveStep(amountOfDisc-1,two,one,three);         }    }    private void autoMoveDisc(char cStart,char cEnd){       Disc disc=null;       if(cStart==towerName[0]){                for(int i=0;i<pointA.length;i++){                   if(pointA[i].isHaveDisc()==true){                       disc=pointA[i].getDiscOnPoint();                       pointA[i].setHaveDisc(false);                            break;                   }                }       }       if(cStart==towerName[1]){                for(int i=0;i<pointB.length;i++){                   if(pointB[i].isHaveDisc()==true){                       disc=pointB[i].getDiscOnPoint();                       pointB[i].setHaveDisc(false);                       break;                   }                }       }       if(cStart==towerName[2]){                for(int i=0;i<pointC.length;i++){                   if(pointC[i].isHaveDisc()==true){                       disc=pointC[i].getDiscOnPoint();                       pointC[i].setHaveDisc(false);                       break;                   }                }       }       TowerPoint endPoint=null;       int i=0;           if(cEnd==towerName[0]){                for(i=0;i<pointA.length;i++){                   if(pointA[i].isHaveDisc()==true){                      if(i>0){                                                                               endPoint=pointA[i-1];                         break;                      }                      else if(i==0)                         break;                   }                }                if(i==pointA.length)                  endPoint=pointA[pointA.length-1];       }       if(cEnd==towerName[1]){                for(i=0;i<pointB.length;i++){                   if(pointB[i].isHaveDisc()==true){                                                      if(i>0){                                                                               endPoint=pointB[i-1];                         break;                      }                      else if(i==0)                         break;                   }                }                if(i==pointB.length)                  endPoint=pointB[pointB.length-1];       }       if(cEnd==towerName[2]){                for(i=0;i<pointC.length;i++){                   if(pointC[i].isHaveDisc()==true){                                                      if(i>0){                                                                               endPoint=pointC[i-1];                         break;                      }                      else if(i==0)                         break;                   }                   }                if(i==pointC.length)                  endPoint=pointC[pointC.length-1];       }       if(endPoint!=null&&disc!=null){              endPoint.putDisc(disc,con);              endPoint.setHaveDisc(true);       }    } }

java 汉诺塔实现自动演示的更多相关文章

  1. Java汉诺塔算法

    汉诺塔问题[又称河内塔]是印度的一个古老的传说. 据传开天辟地之神勃拉玛在一个庙里留下了三根金刚石的棒,第一根上面套着64个圆的金片,最大的一个在底下,其余一个比一个小,依次叠上去,庙里的众僧不倦地把 ...

  2. JAVA——汉诺塔

    大家还记得某年春晚小品那个把大象放冰箱需要几步吗? 今天,我准备写的是汉诺塔,有三个魔法石柱,分别:诚实.勇敢.正直.其中有一个石柱上从大到小,从地向上依次排放着四个魔法圆环,需要将那四个魔法圆环分别 ...

  3. Java-Runoob-高级教程-实例-方法:03. Java 实例 – 汉诺塔算法-un

    ylbtech-Java-Runoob-高级教程-实例-方法:03. Java 实例 – 汉诺塔算法 1.返回顶部 1. Java 实例 - 汉诺塔算法  Java 实例 汉诺塔(又称河内塔)问题是源 ...

  4. 用C语言实现汉诺塔自动递归演示程序

    用C语言实现汉诺塔自动递归演示程序 程序实现效果 1.变界面大小依照输入递归数改变. 2.汉诺塔自动移动演示. 3.采用gotoxy实现流畅刷新. 4.保留文字显示递归流程 程序展示及实现 githu ...

  5. 算法笔记_013:汉诺塔问题(Java递归法和非递归法)

    目录 1 问题描述 2 解决方案  2.1 递归法 2.2 非递归法 1 问题描述 Simulate the movement of the Towers of Hanoi Puzzle; Bonus ...

  6. 编程:递归编程解决汉诺塔问题(用java实现)

    Answer: //Li Cuiyun,October 14,2016. //用递归方法编程解决汉诺塔问题 package tutorial_3_5; import java.util.*; publ ...

  7. Java递归算法——汉诺塔问题

    //================================================= // File Name : Tower_demo //-------------------- ...

  8. java 解决汉诺塔问题

    //汉诺塔问题//HanYang 2016/10/15 import java.util.Scanner; //输出public class Hanuota { public static void ...

  9. java 中递归的实现 以及利用递归方法实现汉诺塔

    今天说下java语言中比较常见的一种方法,递归方法. 递归的定义 简单来说递归的方法就是"自己调用自己",通过递归方法往往可以将一个大问题简单化,最终压缩到一个易于处理的程度.对于 ...

随机推荐

  1. Javascript中call,apply,bind的区别

    一.探索call方法原理 Function.prototype.call = function(obj) { // 1.让fn中的this指向obj // eval(this.toString().r ...

  2. centOS7升级git版本到2.7.3

    CentOS 自带的git版本太低,需要升级到2.1.2版本以上才能使用gitea. 升级方法: 1.安装所需软件包 yum install curl-devel expat-devel gettex ...

  3. LOJ.6062.[2017山东一轮集训]Pair(Hall定理 线段树)

    题目链接 首先Bi之间的大小关系没用,先对它排序,假设从小到大排 那么每个Ai所能匹配的Bi就是一个B[]的后缀 把一个B[]后缀的匹配看做一条边的覆盖,设Xi为Bi被覆盖的次数 容易想到 对于每个i ...

  4. Cesiumjs初学第一天

    官网demo地址: https://cesiumjs.org/Cesium/Apps/Sandcastle/?src=Geometry%20and%20Appearances.html&lab ...

  5. NullPointerExceptio异常出现的情况

    NullPointerException是java.lang.NullPointerException的简称,是Java语言中的一个异常类,位于java.lang包中,父类是java.lang.Run ...

  6. CocosCreator资源工作流程

    --摘自官方文档 资源工作流程 添加资源 资源管理器 提供了三种在项目中添加资源的方式: 通过 创建按钮 添加资源 在操作系统的文件管理器中,将资源文件复制到项目资源文件夹下,之后再打开或激活 Coc ...

  7. javascript中用正则表达式判断是否为汉字及常用的判断

    a.判断是否为汉字: 1.汉字为任意长度时: var han = /^[\u4e00-\u9fa5]+$/; 例如: var han = /^[\u4e00-\u9fa5]+$/; var vals= ...

  8. 内置系统账户:Local system/Network service/Local Service 区别

    参考文献: http://www.cnblogs.com/xianspace/archive/2009/04/05/1429835.html 前言 今天在安装sqlserver2008 r2的时候,在 ...

  9. JSON序列——根据JSON生成事务性SQL2

    JSON序列——根据JSON生成事务性SQL2 procedure TForm1.Button3Click(Sender: TObject); begin var json:string:=''+ ' ...

  10. Knockout.Js官网学习(enable绑定、disable绑定)

    enable绑定 enable绑定使DOM元素只有在参数值为 true的时候才enabled.在form表单元素input,select,和textarea上非常有用. enable简单示例 < ...