063.汉诺塔问题
490
2022-05-28
var delay = 200; //in milliseconds
var drag=false;
var objDisk=null;
var x = 0;
var y = 0;
var disksOnTower1 = new Array(null,null,null,null,null,null,null,null);
var disksOnTower2 = new Array(null,null,null,null,null,null,null,null);
var disksOnTower3 = new Array(null,null,null,null,null,null,null,null);
var disksOnTowers = new Array(disksOnTower1,disksOnTower2,disksOnTower3);
var offsetleft = 30;
var offsettop = 30;
var offsettower = 20;
var offsethoriz = 30;
var basetop = 0;
var diskheight = 0;
var midhoriztower = 0;
var indexTo=1;
var indexFr=1;
var movectr=0;
var gameOver=false;
var prevIndex=0;
var zindex = 0;
var currTower=1;
var prevTower=1;
var demo=false;
var arrFr = new Array(255);
var arrTo = new Array(255);
var idx = 0;
var pos = 0;
var t=null;
var stop=false;
function init(){
if (document.getElementById){
var diskno = document.hanoi.diskno;
diskno.options.selectedIndex = 0;
drawTowers();
drawDisks(parseInt(diskno.options[diskno.options.selectedIndex].text));
}
}
function initVars(){
for (var i=0;i disksOnTower1[i]=null; disksOnTower2[i]=null; disksOnTower3[i]=null; } drag = false; indexTo = 1; indexFr = 1; movectr = 0; zindex = 0; idx = 0; pos = 0; t = null; gameOver=false; stop=false; demo=false; document.hanoi.btnUndo.disabled=true; } function drawTowers(){ var title=document.getElementById("title"); var tower1=document.getElementById("tower1"); var tower2=document.getElementById("tower2"); var tower3=document.getElementById("tower3"); var settings=document.getElementById("settings"); var titlewidth = parseInt(title.style.width); var titleheight = parseInt(title.style.height); var towerwidth = parseInt(tower1.style.width); var towerheight = parseInt(tower1.style.height); var settingswidth = parseInt(settings.style.width); midhoriztower = parseInt(document.getElementById("horiztower1").style.width)/2; diskheight = parseInt(document.getElementById("disk1").style.height); title.style.left=offsetleft+(1.5*towerwidth)+offsettower-(titlewidth/2)+"px"; title.style.top=offsettop+"px"; tower1.style.left=offsetleft+"px"; tower1.style.top=offsettop+titleheight+offsethoriz+"px"; tower2.style.left=offsetleft+towerwidth+offsettower+"px"; tower2.style.top=offsettop+titleheight+offsethoriz+"px"; tower3.style.left=offsetleft+(towerwidth+offsettower)*2+"px"; tower3.style.top=offsettop+titleheight+offsethoriz+"px"; settings.style.left=offsetleft+(1.5*towerwidth)+offsettower-(settingswidth/2)+"px"; settings.style.top=parseInt(tower1.style.top)+towerheight+offsethoriz+"px"; } function drawDisks(disknum){ var tower1=document.getElementById("tower1"); var disktop = parseInt(tower1.style.top)+parseInt(document.getElementById("horiztower1").style.top); var lefttower1 = parseInt(tower1.style.left); var disk; var f=document.hanoi; basetop = disktop; for (var i=disksOnTower1.length;i>=1;i--){ disk = document.getElementById("disk"+i); disk.style.zIndex=++zindex; if (i<=disknum){ disk.style.left=lefttower1+midhoriztower-parseInt(disk.style.width)/2+"px"; disk.style.top=disktop-diskheight-1+"px"; disktop = parseInt(disk.style.top); disksOnTowers[0][i-1]=disk; } else { disk.style.left="-250px"; disk.style.top="-250px"; disksOnTowers[0][i-1]=null; } } f.minmove.value=f.diskno.options[f.diskno.options.selectedIndex].value; f.yourmove.value=0; } function newGame(obj){ if (movectr>0 && !gameOver && !stop){ if (confirm("Current game will be aborted, would you like to continue?")){ initVars(); drawDisks(parseInt(obj.options[obj.options.selectedIndex].text)); } else document.hanoi.diskno.options.selectedIndex=prevIndex; } else { initVars(); drawDisks(parseInt(obj.options[obj.options.selectedIndex].text)); } } function initializeDrag(disk,e){ if (!e) e=event; if (stop){ swal("警告", "不能在点击'stop'按钮之后在继续执行移动盘子的操作!!", "warning"); //alert("You cannot continue solving the puzzle after clicking the 'Stop' button.\nClick 'Restart' button or select no. of disks to continue playing."); return; } indexFr = indexTo; if (disk.id!=disksOnTowers[indexFr-1][0].id || gameOver || demo) return; objDisk=disk; x=e.clientX; y=e.clientY; tempx=parseInt(disk.style.left); tempy=parseInt(disk.style.top); document.onmousemove=dragDisk; } function dragDisk(e){ if (!e) e=event; zindex++; drag=true; var posX = tempx+e.clientX-x; var posY = tempy+e.clientY-y; var objTower1 = document.getElementById("tower1"); var objTower2 = document.getElementById("tower2"); var objTower3 = document.getElementById("tower3"); var tower1Left = parseInt(objTower1.style.left); var tower2Left = parseInt(objTower2.style.left); var tower3Left = parseInt(objTower3.style.left); var tower3Width = parseInt(objTower3.style.width); objDisk.style.zIndex=zindex; objDisk.style.left=posX+'px'; objDisk.style.top=posY+'px'; if (e.clientX>=document.body.clientWidth-10 || e.clientY>=document.body.clientHeight-5 || e.clientX==5 || e.clientY==5){ //outside available window indexTo=indexFr; dropDisk(objDisk); } else if ( //in the vicinity of tower 3 (tower3Left<=posX) && (tower3Left+tower3Width>=posX) && (parseInt(objTower3.style.top)+parseInt(objTower3.style.height)>posY) ){ indexTo=3; } else if ((tower2Left<=posX) && (tower2Left+tower3Width>=posX)){ //in the vicinity of tower 2 indexTo=2; } else if ((tower1Left<=posX) && (tower1Left+parseInt(objTower1.style.width)>=posX)){ //in the vicinity of tower 1 indexTo=1; } else indexTo = indexFr; return false; } function dropDisk(disk){ var f=document.hanoi; document.onmousemove=new Function("return false"); if (!drag) return; var gameStatus=false; var topDisk = disksOnTowers[indexTo-1][0]; if (indexFr==indexTo){ getNewTop(indexFr,null); pushDisk(disk,indexFr); //put disk back to original tower getNewTop(indexFr,disk); } else if (topDisk==null) { pushDisk(disk,indexTo); getNewTop(indexFr,null); getNewTop(indexTo,disk); movectr++; currTower=indexTo; prevTower=indexFr; f.btnUndo.disabled=false; } else if (parseInt(disk.style.width) pushDisk(disk,indexTo); getNewTop(indexFr,null); getNewTop(indexTo,disk); movectr++; currTower=indexTo; prevTower=indexFr; if (indexTo==3) gameStatus=checkStatus(); f.btnUndo.disabled=false; } else { getNewTop(indexFr,null); pushDisk(disk,indexFr); //put disk back to original tower getNewTop(indexFr,disk); } drag=false; f.yourmove.value=movectr; if (gameStatus) { f.btnUndo.disabled=true; minmove = parseInt(f.minmove.value); if (movectr==minmove) msg="\nCongratulations! You got it in "+minmove+" moves." else if (movectr>minmove) msg="\nYou can do better than that." else msg=""; //alert("Game Over !!!"+msg); swal({ title: "干的漂亮!!!!", text: msg, imageUrl: "images/thumbs-up.jpg" }); gameOver=true; } return; } function checkStatus(){ var gameStat = false; var disks=0; for (var i=0;i if (disksOnTowers[2][i]!=null) disks++; } if (disks==parseInt(document.hanoi.diskno.options[document.hanoi.diskno.options.selectedIndex].text)) gameStat=true; return gameStat; } function pushDisk(disk,index){ var diskWidth = parseInt(disk.style.width); var towerLeft = parseInt(document.getElementById("tower"+index).style.left); var topDisk = disksOnTowers[index-1][0]; if (topDisk!=null){ topDiskWidth = parseInt(topDisk.style.width); topDiskTop = parseInt(topDisk.style.top); disk.style.left=towerLeft+midhoriztower-diskWidth/2+"px"; disk.style.top=topDiskTop-diskheight-1+"px"; } else { disk.style.left=towerLeft+midhoriztower-diskWidth/2+"px"; disk.style.top=basetop-diskheight-1+"px"; } } function getNewTop(index,disk){ if (disk==null){ //pop for (var i=0;i disksOnTowers[index-1][i]=disksOnTowers[index-1][i+1]; } disksOnTowers[index-1][disksOnTower1.length-1]=null; } else { //push for (var i=disksOnTower1.length-1;i>=1;i--){ disksOnTowers[index-1][i]=disksOnTowers[index-1][i-1]; } disksOnTowers[index-1][0]=disk; } } function solve(btn){ if (btn.value=="Solve"){ if (movectr>0 && !gameOver && !stop) if (!confirm("Current game will be aborted, would you like to continue?")) return; btn.value="Stop"; initVars(); stop=false; demo=true; var f=document.hanoi; f.btnIns.disabled=true; f.btnRes.disabled=true; f.btnUndo.disabled=true; disknum = parseInt(f.diskno.options[f.diskno.options.selectedIndex].text); drawDisks(disknum); getMoves(0, 2, 1, disknum); t=window.setTimeout("moveDisk()",delay); } else { if (t) { window.clearTimeout(t); btn.value="Solve"; frm.btnIns.disabled=false; frm.btnRes.disabled=false; t = null; stop=true; demo=false; } } } function moveDisk(){ frm = document.hanoi; disk=disksOnTowers[arrFr[pos]][0]; pushDisk(disk,arrTo[pos]+1); getNewTop(arrFr[pos]+1,null); getNewTop(arrTo[pos]+1,disk); movectr++; frm.yourmove.value=movectr; pos++; if (movectr else { //alert("Can you do that in "+movectr+" moves?"); swal({ title: "搞定了!", text: movectr+"步!你还能够更快完成它吗?", imageUrl: "images/pinpin.png" }); //swal("Can you do that in "+movectr+" moves?"); gameOver=true; stop=false; frm.btnSolve.value="Solve"; frm.btnIns.disabled=false; frm.btnRes.disabled=false; } } function getMoves(from,to,empty,numDisk){ if (numDisk > 1) { getMoves(from, empty, to, numDisk - 1); arrFr[idx] = from; arrTo[idx++] = to; getMoves(empty, to, from, numDisk - 1); } else { arrFr[idx] = from; arrTo[idx++] = to; } } function unDo(btn){ disk=disksOnTowers[currTower-1][0]; pushDisk(disk,prevTower); getNewTop(currTower,null); getNewTop(prevTower,disk); movectr--; document.hanoi.yourmove.value=movectr; btn.disabled=true; } function displayIns(){ var msg = "你要将所有的盘子从TOWER 1移动到TOWER 3\n"; msg += "你每次只能移动一个盘子。\n"; msg += "游戏最重要的规则是大的盘子不能放在小的盘子上面!"; // var msg="Try to move all the disks from TOWER 1 to TOWER 3.\n"; // msg+="You may only move one disk at a time.\n"; // msg+="You must never allow a bigger disk to go on top of a smaller disk."; //alert(msg); swal({ title: "汉诺塔游戏规则", text: msg, imageUrl: 'images/capitaine.png' }); } html可以找我要 5G游戏
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。