JS實現棋盤覆蓋
這次帶給大家JS實作棋盤覆蓋,JS實作棋盤覆蓋的注意事項有哪些,下面就是實戰案例,一起來看一下。
之前做了一個演算法作業,叫做棋盤覆蓋,本來需要用c語言來寫的,但因為我的c語言是半桶水(哈哈),所以索性就把網路上的c語言寫法改成JavaScript寫法,並且把它的覆蓋效果顯示出來
<!DOCTYPE html> <html> <head><meta http-equiv="Content-Type"content="text/html; charset=utf-8"/> <title>算法作业2</title> <style type="text/css"> #num{} #chess{ margin-top:20px; } </style> </head> <body> <p id="num"> <p>设置棋盘大小: <input type="text"name="Num"size="4"/> </p> <p>请输入特殊方格的位置:</p> <p> x:<input type="text"name="X"size="25"/><br /> y:<input type="text"name="Y"size="25"/> </p> <p> <input type="button"value="设置棋盘参数"/> <input type="button"value="生成棋盘"/> </p> </p> <p id="chess"> </p> </body> </html> <script type="text/javascript"> window.onload=function() {//棋盘设置 varchess=document.getElementById('chess'); varinput=document.getElementsByTagName('input')[3]; input.onclick=function() { varN=document.getElementsByTagName('input')[0].value; vartable=document.createElement('table'); chess.appendChild(table); table.style.border='2px solid'; table.style.borderCollapse='collapse'; for(vari=0;i<N;i++) { vartr=document.createElement('tr'); table.appendChild(tr); tr.style.height ="20px"; tr.style.border='1px solid #ccc'; for(varj=0;j<N;j++) { vartd=document.createElement('td'); tr.appendChild(td); td.style.width ="20px"; td.style.border='1px solid #ccc'; } } } varOut=document.getElementsByTagName('input')[4]; varMatrix =newArray(); for(vari=0;i<100; i++) {//初始化棋盘矩阵 Matrix[i] =newArray(); for(varj=0;j<100;j++) { Matrix[i][j]=0; } } Out.onclick=function() {//棋盘生成 varr,c; varX=document.getElementsByTagName('input')[1].value; varY=document.getElementsByTagName('input')[2].value; varN=document.getElementsByTagName('input')[0].value; chessBoard(0,0,X-1,Y-1,N); for(r = 0; r < N; r++) { for(c = 0; c < N; c++) { varq=Matrix[r][c]; vartable=document.getElementsByTagName('table')[0]; table.rows[r].cells[c].style.background='rgb('+13*q%256+','+43*q%256+','+73*q%256+')'; } } } varnCount = 0; functionchessBoard(tr,tc,dr,dc,size) { vars,t; if(size == 1)return; s =size/2; t = ++nCount ; if(dr < tr + s && dc < tc +s) chessBoard(tr,tc,dr,dc,s); else { Matrix[tr+s-1][tc+s-1] = t; chessBoard(tr,tc,tr+s-1,tc+s-1,s); } if(dr < tr + s && dc >= tc + s ) chessBoard(tr,tc+s,dr,dc,s); else { Matrix[tr+s-1][tc+s] = t; chessBoard(tr,tc+s,tr+s-1,tc+s,s); } if(dr >= tr + s && dc < tc + s) chessBoard(tr+s,tc,dr,dc,s); else { Matrix[tr+s][tc+s-1] = t; chessBoard(tr+s,tc,tr+s,tc+s-1,s); } if(dr >= tr + s && dc >= tc + s) chessBoard(tr+s,tc+s,dr,dc,s); else { Matrix[tr+s][tc+s] = t; chessBoard(tr+s,tc+s,tr+s,tc+s,s); } } } </script>
棋盤覆蓋的C語言程式碼我是參考課本的,為了能夠把它用進JavaScript裡面,突破口就是二維數組Matrix[][],只要能夠獲得它計算之後整個數組的數據,那麼就有思路了。要記得填入表單裡面的資料是在點選按鈕之後才取得的,所以取得元素節點的程式碼要放在onclick裡面。
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
以上是JS實現棋盤覆蓋的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

本文目錄導讀:CentOS覆蓋安裝CentOS7覆蓋安裝為您分享在CentOS作業系統中,經常需要執行覆蓋安裝來解決系統問題或進行更新。本文將詳細介紹CentOS的覆蓋安裝及CentOS7的覆蓋安裝步驟,協助您有效管理與維護系統。 CentOS覆蓋安裝在系統已經安裝的情況下進行CentOS的覆蓋安裝通常是為了修復系統問題或進行更新。在執行此操作之前,請務必備份重要數據,以免遺失。 1.下載最新的CentOS鏡像文件,並製作啟動USB或光碟。 2.將啟動USB或光碟插入計算機,重啟計算機並進入BIOS設置,將
