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. mysql GRANT ALL PRIVILEGES 限制某个或所有客户端都可以连接至mysql

    GRANT ALL PRIVILEGES 1. 改表法.可能是你的帐号不允许从远程登陆,只能在localhost.这个时候只要在localhost的那台电脑,登入mysql后,更改 "mys ...

  2. [HDU5963]朋友

    [HDU5963]朋友 题目大意: 给定一棵\(n(n\le40000)\)个点的树,边权只能是\(0\)或\(1\).一局游戏开始时,会确定一个结点作为根.AB轮流操作.当一方操作时,他们需要先选择 ...

  3. C++ 函数模板基础知识

    为什么要引入模板:为了避免代码重复,程序员可以编写脱离数据类型通用模板. 模板的分类:函数模板 + 类模板 注意:模板的声明或定义只能在全局,命名空间或类范围内进行.不能在函数内进行,比如不能在mai ...

  4. 小程序canvas的一个坑

    很奇怪,原来好好的,结果现在显示乱了,模拟器和手机都不一样.模拟器上,整个canvas都往右偏移了,手机上,右侧有一大片空白. 反复试验,发现问题是:page的对齐方式是center引起的,改为lef ...

  5. GraphQL入门2

    将服务器端的代码升级了一下: var GraphQLSchema = require('graphql').GraphQLSchema; var GraphQLObjectType = require ...

  6. Using std::map with a custom class key

    From: https://www.walletfox.com/course/mapwithcustomclasskey.php If you have ever tried to use a cus ...

  7. Sublime美化配置

    1.主题预览 material主题:https://equinsuocha.io/material-theme/#/default 2.效果预览 { "ignored_packages&qu ...

  8. [Mockito] Spring Unit Testing with Mockito

    It is recommened to write unit testing with Mockito in Spring framework, because it is much faster w ...

  9. 魅族便签,是否能成为国内便签应用的No.1?

    继前不久锤子科技推出便签 Android 新版后,近期魅族在PRO 6公布会上也公布了最新的魅族便签应用.这一次魅族把便签应用拓展到了整个Android体系,也就是说.其它不论什么的Android手机 ...

  10. 使用log4net将C#日志发送到Elasticsearch

    一.安装Elasticsearch 参考前面写的文章:https://www.cnblogs.com/songxingzhu/p/7909486.html 安装完Elasticsearch后,修改/e ...