{"id":39175,"student_id":173,"content":"\n// 老鼠初始化的位置\nvar x = 0;\nvar y = 0;\nconsole.log(maze[0][0].color)\nforever(function(){\n // 繪製紅色老鼠\n pen.fillColor = 'red';\n pen.drawRect(x*width + 1, y*width + 1, width - 2, width - 2);\n \n\n \n maze[x][y].color=\"lightblue\"\n if(x!=31||y!=23){\n \n \nif(maze[x][y].right==true\u0026\u0026maze[x+1][y].color==\"white\"){\n x+=1\n}else if(maze[x][y].bottom==true\u0026\u0026maze[x][y+1].color==\"white\"){\n y+=1\n}else if(maze[x][y].left==true\u0026\u0026maze[x-1][y].color==\"white\"){\n x-=1\n}else if(maze[x][y].top==true\u0026\u0026maze[x][y-1].color==\"white\"){\n y-=1\n}else{\n maze[x][y].color=\"yellow\"\n if(maze[x][y].right==true\u0026\u0026maze[x+1][y].color==\"lightblue\"){\n x+=1\n }else if(maze[x][y].left==true\u0026\u0026maze[x-1][y].color==\"lightblue\"){\n x-=1\n }else if(maze[x][y].bottom==true\u0026\u0026maze[x][y+1].color==\"lightblue\"){\n y+=1\n }else if(maze[x][y].top==true\u0026\u0026maze[x][y-1].color==\"lightblue\"){\n y-=1\n }\n}\n}\n});\n ","created_at":"2018-08-18T21:36:09.661+08:00","updated_at":"2019-11-09T08:11:04.497+08:00","name":"老鼠走迷宮 - DFS 演算法 副本","language":"javascript","screenshot":{"url":"https://cdn8.koding.school/uploads/project/screenshot/39175/99ec71fa2b2f051346713715d3034115.jpg"},"parent_id":31655,"plugin":"var maze = [];\nvar width = 20;\nvar row = 640/width;\nvar col = 480/width;\n\n(function () {\n for (var x = 0; x \u003c row; x++) {\n maze[x] = [];\n for (var y = 0; y \u003c col; y++) {\n maze[x][y] = {\n color: '#ffffff',\n top: false,\n right: false,\n bottom: false,\n left: false\n };\n }\n }\n \n forever(function() {\n for (var cx = 0; cx \u003c row; cx++) {\n for (var cy = 0; cy \u003c col; cy++) {\n \n var cell = maze[cx][cy];\n pen.size = 0.001;\n pen.fillColor = cell.color;\n pen.drawRect(cx*width, cy*width, width, width);\n \n pen.size = 1;\n var x = cx*width;\n var y = cy*width;\n if (!cell.top) pen.drawLine(x, y, x + width, y);\n if (!cell.right) pen.drawLine(x + width, y, x + width, y + width);\n if (!cell.bottom) pen.drawLine(x, y + width, x + width, y + width);\n if (!cell.left) pen.drawLine(x, y + width, x, y);\n }\n }\n });\n \n var x = 0;\n var y = 0;\n var steps = [];\n maze[0][0].color = 'lightblue';\n \n while(true) {\n pen.fillColor = 'red';\n pen.drawRect(x*width, y*width, width, width);\n \n var next = getNeighbors();\n if (next.length \u003e 0) {\n steps.push({x: x, y: y});\n \n var rand = Math.floor(Math.random()*next.length);\n if (next[rand] == 'top') {\n maze[x][y].top = true;\n y -= 1;\n maze[x][y].bottom = true;\n }\n if (next[rand] == 'right') {\n maze[x][y].right = true;\n x += 1;\n maze[x][y].left = true;\n }\n if (next[rand] == 'bottom') {\n maze[x][y].bottom = true;\n y += 1;\n maze[x][y].top = true;\n }\n if (next[rand] == 'left') {\n maze[x][y].left = true;\n x -= 1;\n maze[x][y].right = true;\n }\n maze[x][y].color = 'lightblue';\n } else {\n maze[x][y].color = 'white';\n if (steps.length \u003e 0) {\n var back = steps.pop();\n x = back.x;\n y = back.y;\n }\n }\n \n var count = 0;\n for (var c1 = 0; c1 \u003c row; c1++) {\n for (var c2 = 0; c2 \u003c col; c2++) {\n if (maze[c1][c2].color == 'white') {\n count++;\n }\n }\n }\n if (count \u003e= row*col) break;\n };\n \n function getNeighbors () {\n var arr = [];\n if (check(x + 1, y)) {\n arr.push('right');\n }\n if (check(x - 1, y)) {\n arr.push('left');\n }\n if (check(x, y + 1)) {\n arr.push('bottom');\n }\n if (check(x, y - 1)) {\n arr.push('top');\n }\n return arr;\n }\n \n function check (x, y) {\n return x \u003e= 0 \u0026\u0026 x \u003c row \u0026\u0026\n y \u003e= 0 \u0026\u0026 y \u003c col \u0026\u0026\n maze[x][y].color == '#ffffff';\n }\n})();","description":null,"note":null,"status":"public","like_student_ids":[],"is_featured":false,"views":80,"hashid":"gk4s88dy","is_content_changed":false,"review_status":"unsubmitted","submitted_at":null,"reviewed_at":null,"advise":null,"is_deleted":false}
[]
橘蘋學習平台
橘蘋學習平台
我的作品
檢視專案頁
匯出
複製
匯入
刪除
下載 Android APP (APK)
截圖
1:1:1
1:1
full
幫助
用手機掃描下方 QRCode 進行安裝
或您也可以
下載 APK
到這台電腦
用手機掃描下方 QRCode 進行安裝
或您也可以
下載 APK
到這台電腦