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. WinForm 屏保程序

    this.ShowInTaskbar = false; this.FormBorderStyle = FormBorderStyle.None; this.WindowState = FormWind ...

  2. Python3练习题系列(09)——物以类聚,人以群分

    目标: 用类管理同类事物 解析: 用到“class”的编程语言被称作“Object Oriented Programming(面向对象编程)”语言.首先你需要做出“东西”来,然后你“告诉”这些东西去完 ...

  3. 潭州课堂25班:Ph201805201 爬虫基础 第十三课 cookie (课堂笔记)

    # -*- coding: utf-8 -*- # 斌彬电脑 # @Time : 2018/9/15 0015 4:52 #cookie 是服务器发给浏览器的特殊信息 # 可以理解为一个临时通行证 # ...

  4. [HDU5968]异或密码

    [HDU5968]异或密码 题目大意: 数据共\(T(T\le100)\)组.每组给定一个长度为\(n(n\le100)\)的非负整数序列\(A(A_i\le1024)\),\(m(m\le100)\ ...

  5. linux 删除开头是减号的文件名

    若有一个文件的文件名为 : -testfile 删除方法为 : 输入“rm — -testfile”或”rm ./-testfile”命令便可顺利删除名为“-testfile”的文件. 如果是其他特殊 ...

  6. php null

    null 表示一个变量没有值,并且不区分大小写 在下列情况下一个变量被认为是 NULL: 1.被赋值为 NULL. 2.尚未被赋值. 3.被 unset(). 判断是否为null :  is_null ...

  7. eclipse和jdk的版本问题,比如printf()出错

    1.右键项目选中properties 2.Java Builder Path >>>Libraries>>>选中JRE Syste Library[jre7]然后r ...

  8. C# Redis缓存过期实现延迟通知实战演练

    一.场景描述 在实际开发过程中经常会遇到一些有时效性数据的业务场景,比如订单支付处理超时提醒.当用户在商城上进行下单支付,我们假设如果8小时没有进行支付,那么就后台自动对该笔交易的状态修改为订单关闭取 ...

  9. Android Studio中Run按钮是灰色的问题解决

      打开一个Android Studio工程,发现Run按钮是灰色的 看了网上的一些解决方法,都是说要配置Configuration :比如链接:http://blog.csdn.net/purple ...

  10. 关于Android中EditText自动获取焦点并弹出键盘的相关设置

    在android开发中,关于EditText自动获取焦点弹出键盘,我们可能又是会有让键盘自动弹出的需求,有时可能又会有不想让键盘自动弹出的需求,下面是我所总结的两种方法: 需求:EditText自动获 ...