這次帶給大家JS實作棋盤覆蓋,JS實作棋盤覆蓋的注意事項有哪些,下面就是實戰案例,一起來看一下。
之前做了一個演算法作業,叫做棋盤覆蓋,本來需要用c語言來寫的,但因為我的c語言是半桶水(哈哈),所以索性就把網路上的c語言寫法改成JavaScript寫法,並且把它的覆蓋效果顯示出來
nbsp;html> <meta> <title>算法作业2</title> <style> #num{} #chess{ margin-top:20px; } </style> <p> </p><p>设置棋盘大小: <input> </p> <p>请输入特殊方格的位置:</p> <p> x:<input><br> y:<input> </p> <p> <input> <input> </p> <p> </p> <script> 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中文網其他相關文章!

javaandjavascriptaredistinctlanguages:javaisusedforenterpriseandmobileapps,while javascriptifforInteractiveWebpages.1)JavaisComcompoppored,statieldinglationallyTypted,statilly tater astrunsonjvm.2)

JavaScript核心數據類型在瀏覽器和Node.js中一致,但處理方式和額外類型有所不同。 1)全局對像在瀏覽器中為window,在Node.js中為global。 2)Node.js獨有Buffer對象,用於處理二進制數據。 3)性能和時間處理在兩者間也有差異,需根據環境調整代碼。

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

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

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

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

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