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. 用单片机控制LED灯(项目)

    #include <reg52.h> #define uchar unsigned char sbit LED_RED = P2^; sbit LED_GREEN = P2^; sbit ...

  2. WordPress基础:极简手动安装教程

    1.下载WordPress 2.将解压后的文件夹,放到网站根目录,并重命名为你喜欢的目录如:w, 3.重命名文件wp-config-sample.php 为 wp-config.php,并进行配置 4 ...

  3. Java全栈程序员之01:做个Linux下的程序猿

    Windows10正在成为史上口碑最差的Windows系统 (图侵删) 我曾经花了数次1小时去寻找解决方案去关闭自动更新,包括停掉服务.修改注册表等等.但是都没有成功. 微软自身是知道这个问题的,但就 ...

  4. bayer格式

    1 图像bayer格式介绍 bayer格式图片是伊士曼·柯达公司科学家Bryce Bayer发明的,Bryce Bayer所发明的拜耳阵列被广泛运用数字图像. 对于彩色图像,需要采集多种最基本的颜色, ...

  5. Altium Designer 13 安装完整元件库

    Altium Designer更新的非常快,都快赶上chrome了,13出来没多久14又出来了,之前一直用AD9.4,算是10之前的最后一个版本,也是很经典的一个版本.安装新版本后看到在目录结构上有些 ...

  6. Spring Boot异常处理

    一.默认映射 我们在做Web应用的时候,请求处理过程中发生错误是非常常见的情况.Spring Boot提供了一个默认的映射:/error,当处理中抛出异常之后,会转到该请求中处理,并且该请求有一个全局 ...

  7. Android四大组件应用系列——Activity与Service交互实现APK下载

    Servic与Activity相比它没有界面,主要是在后台执行一些任务,Service有两种启动方法startService()和bindService(),startService方式Service ...

  8. 版本控制-GitHub

    前面几篇文章,我们介绍了Git的基本用法及Git服务器的搭建,本篇文章来学习一下如何使用GitHub.GitHub是开源的代码库以及版本控制库,是目前使用网络上使用最为广泛的服务,GitHub可以托管 ...

  9. MDX Cookbook 03 - MDX 查询中负数,零和空值 NULL 的格式化处理

    FORMAT_STRING 属性在处理计算成员(通常是度量值成员)的时候会经常使用到,比如指定标准 Standard, 货币 Currency 或者 Percent 百分比格式.除此之外,还可以自定义 ...

  10. centos7安装配置mysql5.6

    1. 下载mysql的repo源 $ wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm 2. 安装mysql-co ...