亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? hannoitower.java

?? JAVA寫的圖形化漢諾塔程序 swing實現
?? JAVA
字號:
package chapter1;

import java.awt.Color;
import java.awt.Graphics;
import java.awt.TextArea;

import javax.swing.JPanel;

public class HannoiTower extends JPanel
{
	TowerPoint[] point ;
	Disk[] disk;
	int startX,startY;// the initial coordinate of the disk
	int startI;// the initial tower of the disk 
	int numberOfDisk;
	int width,heigth;// the size of the largest disk i
	char[] towerName = {'A','B','C'};
	TextArea info = null;
	
	public HannoiTower(int number,int w,int h,TextArea area)
	{
		numberOfDisk = number;
		width = w;
		heigth = h;
		info  = area;
		setLayout(null);
		
		disk  =new Disk[numberOfDisk];
		point  = new TowerPoint[numberOfDisk *3];// there are three towers so the number of points is numberOfDisk *3
		
		int space = 20;
		for (int i = 0;i<numberOfDisk;i++)// set the coordinate of the points in tower A
		{
			point[i] = new TowerPoint(40 + width,100+space,false);
			space +=heigth;
		}
		
		 space = 20;
		for (int i = numberOfDisk;i<2*numberOfDisk;i++)// set the coordinate of the points in tower B
		{
			point[i] = new TowerPoint(160+ width,100+space,false);
			space +=heigth;
		}
		
		 space = 20;
		for (int i = 2*numberOfDisk;i<3*numberOfDisk;i++)// set the coordinate of the points in tower C
		{
			point[i] = new TowerPoint(280+ width,100+space,false);
			space +=heigth;
		}
		
		int tempWidth = width;
		int sub = (int)(tempWidth*0.2);//shink the disk by 20 percent as the disk goes higher
		for(int i = numberOfDisk-1;i>=0;i--)
		{
			disk[i] = new Disk(i);
			disk[i].setSize(tempWidth,heigth);
			tempWidth-=sub;
		}
		point[0].setDisk(disk[0],this);
		for(int i = 1;i<numberOfDisk;i++)//set the disk into tower A
		{
			point[i].setDisk(disk[i],this);
			point[i].setIsDisk(true);
		}
	}
	
	public void paintComponent(Graphics g)//connect the tower points 
	{
		super.paintComponent(g);
		
		g.drawLine(point[0].getX(),point[0].getY(),point[numberOfDisk-1].getX(),point[numberOfDisk-1].getY());
		//paint tower A
		g.drawLine(point[numberOfDisk].getX(),point[numberOfDisk].getY()
				,point[numberOfDisk*2-1].getX(),point[numberOfDisk*2-1].getY());
		//paint tower B
		g.drawLine(point[numberOfDisk*2].getX(),point[numberOfDisk*2].getY()
				,point[numberOfDisk*3-1].getX(),point[numberOfDisk*3-1].getY());
		//paint tower C
		
		g.drawLine(point[numberOfDisk-1].getX(),point[numberOfDisk-1].getY()
				,point[numberOfDisk*3-1].getX(),point[numberOfDisk*3-1].getY());
		//paint the horizonal line frome tower A to C
		
		int leftx  = point[numberOfDisk-1].getX()-width;
		int lefty  = point[numberOfDisk-1].getY();
		int w  = (point[numberOfDisk*3-1].getX() + width )-(point[numberOfDisk-1].getX()-width);// the line's length
		int h = heigth /2;
		g.setColor(Color.lightGray);// the color of the horizonal line frome tower A to C
		g.fillRect(leftx,lefty,w,h);
		
		g.setColor(Color.GREEN);// the color of each point
		
		int size = 4;//the size of the point 
		
		for(int i=0;i<numberOfDisk*3;i++)//draw the points in each tower
			g.fillOval(point[i].getX()-size/2,point[i].getY()-size/2,size,size);
		g.drawString(" "+towerName[0]+" Tower",point[numberOfDisk-1].getX(),point[numberOfDisk-1].getY()+30);
		g.drawString(" "+towerName[1]+" Tower",point[numberOfDisk*2-1].getX(),point[numberOfDisk-1].getY()+30);
		g.drawString(" "+towerName[2]+" Tower",point[numberOfDisk*3-1].getX(),point[numberOfDisk-1].getY()+30);
	
		
	}
	public void autoShow(int numberOfDisk,char from,char auxliary,char to)
	{
		if(numberOfDisk==1)
		{// base case
			info.append("D"+numberOfDisk+" "+from +" to "+to+"\n");
			Disk topdisk = getTopDisk(from);
			int startI = getTopDiskLocation(from);
			int endI   = getAboveTopDiskLocation(to);//get the destination
			if(topdisk !=null)
			{
				point[endI].setDisk(topdisk,this);
				point[startI].setIsDisk(false);
				try{
					Thread.sleep(1000);
				}catch(Exception e){}
			}
		}
		else
		{
			//using recusive 
			autoShow(numberOfDisk-1,from,to,auxliary);
			info.append("D"+numberOfDisk+" "+from +" to "+to+"\n");
			Disk topdisk = getTopDisk(from);
			int startI = getTopDiskLocation(from);
			int endI   = getAboveTopDiskLocation(to);//get the destination
			if(topdisk !=null)
			{
				point[endI].setDisk(topdisk,this);
				point[startI].setIsDisk(false);
				try{
					Thread.sleep(1000);
				}catch(Exception e){}
			}
			autoShow(numberOfDisk-1,auxliary,from,to);
		}
	}
	public Disk getTopDisk(char tower)
	{
		Disk disk = null;
		if(tower == towerName[0])
		{
			for(int i=0;i<numberOfDisk;i++)
			{
				if(point[i].aDisk)//if it is a disk
				{
					disk  = point[i].getDisk();
					break;
				}
			}
		}
		if(tower == towerName[1])
		{
			for(int i=numberOfDisk;i<numberOfDisk*2;i++)
			{
				if(point[i].aDisk)//if it is a disk
				{
					disk  = point[i].getDisk();
					break;
				}
			}
		}
		if(tower == towerName[2])
		{
			for(int i=numberOfDisk*2;i<numberOfDisk*3;i++)
			{
				if(point[i].aDisk)//if it is a disk
				{
					disk  = point[i].getDisk();
					break;
				}
			}
		}
		return disk;
	}
	public int getAboveTopDiskLocation(char tower)
	{
		int position= 0;
		if(tower == towerName[0])
		{   int i =0;
			for( i=0;i<numberOfDisk;i++)
			{
				if(point[i].aDisk)//if it is a disk
				{
					position = Math.max(i-1,0);
					break;
				}
			}
			if(i==numberOfDisk)
			position = numberOfDisk -1;
	     }
		
		if(tower == towerName[1])
		{   int i =0;
			for(i=numberOfDisk;i<numberOfDisk*2;i++)
			{
				if(point[i].aDisk)//if it is a disk
				{
					position = Math.max(i-1,0);
					break;
				}
			}
			if(i==numberOfDisk*2)
			position = numberOfDisk*2 -1;
	     }
		if(tower == towerName[2])
		{   int i =0;
			for(i=numberOfDisk*2;i<numberOfDisk*3;i++)
			{
				if(point[i].aDisk)//if it is a disk
				{
					position = Math.max(i-1,0);
					break;
				}
			}
			if(i==numberOfDisk*3)
			position = numberOfDisk*3 -1;
	     }
		return position;
	}	

public int getTopDiskLocation(char tower)
{
	int position =0;
	if(tower == towerName[0])
	{   int i =0;
		for( i=0;i<numberOfDisk;i++)
		{
			if(point[i].aDisk)//if it is a disk
			{
				position =i;
				break;
			}
		}
		if(i==numberOfDisk)
		position = numberOfDisk -1;
     }
	if(tower == towerName[1])
	{   int i =0;
		for( i=numberOfDisk;i<numberOfDisk*2;i++)
		{
			if(point[i].aDisk)//if it is a disk
			{
				position =i;
				break;
			}
		}
		if(i==numberOfDisk*2)
		position = numberOfDisk*2 -1;
     }
	if(tower == towerName[2])
	{   int i =0;
		for( i=numberOfDisk*2;i<numberOfDisk*3;i++)
		{
			if(point[i].aDisk)//if it is a disk
			{
				position =i;
				break;
			}
		}
		if(i==numberOfDisk*3)
		position = numberOfDisk*3-1;
     }
	return position;
  }
}
	

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久天堂av| 五月天丁香久久| 欧美国产日韩a欧美在线观看| 日韩一区二区麻豆国产| 欧美卡1卡2卡| 欧美在线制服丝袜| 欧洲av在线精品| 欧美日韩高清影院| 日韩一区二区视频| 欧美精品 国产精品| 7799精品视频| 欧美一区二区三区不卡| 日韩欧美电影一区| 久久婷婷综合激情| 国产女人18水真多18精品一级做| 国产色91在线| 亚洲天堂久久久久久久| 亚洲国产va精品久久久不卡综合| 天天综合色天天| 麻豆精品一区二区av白丝在线| 久久国产综合精品| 国产成人免费在线观看不卡| 不卡的电影网站| 欧美怡红院视频| 91精品国产全国免费观看| 精品va天堂亚洲国产| 日本一区二区成人在线| 一区二区三区四区精品在线视频 | 高清不卡在线观看| 99久久亚洲一区二区三区青草| 在线观看91精品国产入口| 日韩亚洲欧美在线| 国产欧美日产一区| 亚洲一区二区三区小说| 另类综合日韩欧美亚洲| 成人性视频免费网站| 在线视频一区二区三区| 精品久久久影院| 国产精品成人网| 天天综合网天天综合色| 国产精品自在在线| 91久久人澡人人添人人爽欧美| 欧美精品高清视频| 久久久精品一品道一区| 一区二区三区精品久久久| 麻豆精品一区二区三区| 99视频一区二区| 91精品国产综合久久香蕉的特点| 国产欧美日产一区| 日韩在线a电影| 成人性生交大片免费看视频在线| 欧美日韩国产美| 国产欧美日韩麻豆91| 亚洲超碰精品一区二区| 成人一区二区视频| 欧美精选一区二区| 中文字幕中文字幕一区| 免费久久99精品国产| 99热精品一区二区| 欧美v亚洲v综合ⅴ国产v| 一区二区在线观看视频| 国产呦萝稀缺另类资源| 欧美日韩二区三区| 日韩一区有码在线| 国产在线视视频有精品| 欧美日韩国产精品自在自线| 国产精品毛片a∨一区二区三区| 日本女人一区二区三区| 色诱视频网站一区| 国产视频一区二区在线| 欧美aaaaaa午夜精品| 色94色欧美sute亚洲线路二| 久久精品一区蜜桃臀影院| 丝袜美腿亚洲色图| 日本高清不卡aⅴ免费网站| 国产欧美日韩在线看| 久久超碰97中文字幕| 欧美日韩极品在线观看一区| 亚洲日本免费电影| 成人爽a毛片一区二区免费| 欧美成人免费网站| 日本特黄久久久高潮| 欧美在线观看你懂的| 国产精品美女一区二区| 国产成人在线色| 欧美v日韩v国产v| 麻豆免费精品视频| 欧美一区二区在线不卡| 亚洲一区二区三区在线播放| 91麻豆产精品久久久久久| 国产精品视频你懂的| 国产精品一区二区久久不卡| 26uuu久久综合| 狠狠色狠狠色综合系列| 精品国产一区二区三区忘忧草| 人人爽香蕉精品| 欧美高清精品3d| 亚洲成人动漫在线免费观看| 欧美色图在线观看| 亚洲国产日日夜夜| 欧美日韩精品久久久| 午夜成人在线视频| 欧美丰满少妇xxxbbb| 日韩国产欧美三级| 欧美岛国在线观看| 极品尤物av久久免费看| 26uuuu精品一区二区| 国产乱理伦片在线观看夜一区| 久久综合狠狠综合久久激情| 国产一区二区影院| 国产亚洲欧美日韩俺去了| 国产另类ts人妖一区二区| 国产亚洲自拍一区| 成人在线一区二区三区| 亚洲手机成人高清视频| 欧美性一级生活| 爽爽淫人综合网网站| 日韩一级完整毛片| 国产精品亚洲一区二区三区妖精 | 中文字幕在线播放不卡一区| www.成人在线| 一区二区三区影院| 91精品国产免费| 国产主播一区二区三区| 亚洲国产精品国自产拍av| 成人的网站免费观看| 亚洲精品视频在线| 7777精品伊人久久久大香线蕉的 | 91国产视频在线观看| 婷婷丁香久久五月婷婷| 精品欧美久久久| 国产成人免费视| 一区二区三区加勒比av| 欧美一区在线视频| 国产91丝袜在线播放九色| 亚洲男人电影天堂| 在线不卡欧美精品一区二区三区| 久久成人麻豆午夜电影| 国产精品女同一区二区三区| 日本韩国精品在线| 美女视频免费一区| 欧美国产亚洲另类动漫| 91黄色免费观看| 久久精品理论片| 日韩一区欧美小说| 日韩丝袜情趣美女图片| 成人黄色软件下载| 日韩制服丝袜先锋影音| 欧美国产乱子伦| 欧美视频自拍偷拍| 国产成人精品亚洲777人妖 | 亚洲免费高清视频在线| 91精品国产aⅴ一区二区| 丰满亚洲少妇av| 午夜精品影院在线观看| 国产日产欧产精品推荐色| 欧美日韩中文字幕一区| 国产91丝袜在线18| 天天综合色天天综合| 国产精品久久久久婷婷| 欧美日韩精品一区二区三区蜜桃 | 视频一区中文字幕| 国产精品嫩草99a| 欧美一区二区三区婷婷月色| caoporn国产精品| 美女视频黄频大全不卡视频在线播放 | 91精品国产综合久久香蕉麻豆 | 欧美日韩专区在线| 国产成人亚洲精品狼色在线| 亚洲第一在线综合网站| 国产精品色哟哟网站| 欧美一级电影网站| 色屁屁一区二区| 成人精品高清在线| 精品一区二区三区在线观看| 亚洲国产色一区| 亚洲欧美在线另类| 国产午夜亚洲精品羞羞网站| 91精品国产全国免费观看| 欧美伊人久久久久久久久影院 | 欧美精品1区2区3区| 99riav久久精品riav| 国产伦精品一区二区三区视频青涩| 首页国产丝袜综合| 一区二区三区中文在线| 亚洲欧洲av一区二区三区久久| 久久久精品中文字幕麻豆发布| 日韩一区二区免费电影| 欧美区在线观看| 欧美在线不卡视频| 色综合久久综合| 成人精品gif动图一区| 国产一区福利在线| 久久国内精品自在自线400部| 午夜精品久久久久久久久久| 亚洲一区二区精品视频| 一区二区三区欧美在线观看| 亚洲人成在线播放网站岛国| 久久九九久久九九| 国产欧美一区二区精品性色|