Java實現簡單的掃雷圖
用Java實現簡單的掃雷圖,供大家參考,具體內容如下
掃雷圖的思想是:
1、地圖可以是一個二維數組,并對數組進行初始化
2、隨機生成雷的位置,可以用Random函數進行隨機生成也可以用Math.random()進行隨機生成
(PS:我就是簡單隨機下標生成了雷的位置)
3、對每一個非雷的位置一周的格子進行判斷是否有雷,進行數字的累加
4、遍歷數組進行輸出
private static void mineClearance() { // 聲明一個二維數組表示掃雷地圖 String[][] mineClearanceMap = new String[9][9]; //初始化數組 for (int i = 0; i < mineClearanceMap.length; i++) { for (int j = 0; j < mineClearanceMap.length; j++) { mineClearanceMap[i][j] = '0'; } } Random random = new Random(); //隨機生成地雷 for (int i = 0; i < 25; i++) { mineClearanceMap[random.nextInt(mineClearanceMap.length)][random.nextInt(mineClearanceMap.length)] = '*';// *表示雷 } //mineClearanceMap[i][j]的一周的坐標,用i+x,j+y得到周圍的坐標 int x[] = { -1, -1, -1, 0, 0, 1, 1, 1 }; int y[] = { -1, 0, 1, -1, 1, -1, 0, 1 }; for (int i = 0; i < mineClearanceMap.length - 1; i++) { for (int j = 0; j < mineClearanceMap.length - 1; j++) { int count = 0; if (!'*'.equals(mineClearanceMap[i][j])) { for (int k = 0; k < 8; k++) { int xx = i + x[k]; int yy = j + y[k]; if (xx >= 0 && yy >= 0) {// 坐標不能出界,數組從(0,0)開始 if (mineClearanceMap[xx][yy] == '*') {count = count + 1;// 累計這八個方位的雷總數 } } } mineClearanceMap[i][j] = count + '';// 輸出每個位置周圍的雷數 } } } System.out.println('得到的掃雷圖,*為雷'); for (int j = 0; j < mineClearanceMap.length; j++) { for (int j2 = 0; j2 < mineClearanceMap.length; j2++) { System.out.print(mineClearanceMap[j][j2]); } System.out.println(); } }
運行截圖
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
相關文章:
1. php測試程序運行速度和頁面執行速度的代碼2. ASP中常用的22個FSO文件操作函數整理3. 三個不常見的 HTML5 實用新特性簡介4. Warning: require(): open_basedir restriction in effect,目錄配置open_basedir報錯問題分析5. ASP調用WebService轉化成JSON數據,附json.min.asp6. SharePoint Server 2019新特性介紹7. React+umi+typeScript創建項目的過程8. 無線標記語言(WML)基礎之WMLScript 基礎第1/2頁9. ASP.NET Core 5.0中的Host.CreateDefaultBuilder執行過程解析10. php網絡安全中命令執行漏洞的產生及本質探究
