leetcode529. 掃雷游戲(dfs)

讓我們一起來玩掃雷游戲!

給定一個代表游戲板的二維字符矩陣。 ‘M’ 代表一個未挖出的地雷,‘E’ 代表一個未挖出的空方塊,‘B’ 代表沒有相鄰(上,下,左,右,和所有4個對角線)地雷的已挖出的空白方塊,數字(‘1’ 到 ‘8’)表示有多少地雷與這塊已挖出的方塊相鄰,‘X’ 則表示一個已挖出的地雷。

現在給出在所有未挖出的方塊中(‘M’或者’E’)的下一個點擊位置(行和列索引),根據以下規則,返回相應位置被點擊后對應的面板:

如果一個地雷(‘M’)被挖出,游戲就結束了- 把它改為 ‘X’。
如果一個沒有相鄰地雷的空方塊(‘E’)被挖出,修改它為(‘B’),并且所有和其相鄰的方塊都應該被遞歸地揭露。
如果一個至少與一個地雷相鄰的空方塊(‘E’)被挖出,修改它為數字(‘1’到’8’),表示相鄰地雷的數量。
如果在此次點擊中,若無更多方塊可被揭露,則返回面板。

示例 1:

輸入:

[[‘E’, ‘E’, ‘E’, ‘E’, ‘E’],
[‘E’, ‘E’, ‘M’, ‘E’, ‘E’],
[‘E’, ‘E’, ‘E’, ‘E’, ‘E’],
[‘E’, ‘E’, ‘E’, ‘E’, ‘E’]]

Click : [3,0]

輸出:

[[‘B’, ‘1’, ‘E’, ‘1’, ‘B’],
[‘B’, ‘1’, ‘M’, ‘1’, ‘B’],
[‘B’, ‘1’, ‘1’, ‘1’, ‘B’],
[‘B’, ‘B’, ‘B’, ‘B’, ‘B’]]

代碼

class Solution {public char[][] updateBoard(char[][] board, int[] click) {int[][] dir=new int[][]{{-1,0},{1,0},{0,1},{0,-1},{1,1},{1,-1},{-1,1},{-1,-1}};if(board[click[0]][click[1]]=='M')board[click[0]][click[1]]='X';else  if(board[click[0]][click[1]]=='E')update(board,click[0],click[1],dir);return board;}public void update(char[][] board, int x,int y,int[][] dir) {int sum=0;for(int[] d:dir)//檢查周圍有沒有地雷{int nextX=d[0]+x,nextY=d[1]+y;if(nextX<0||nextY>=board[0].length||nextY<0||nextX>=board.length) continue;if(board[nextX][nextY]=='M') sum++;}if(sum==0) board[x][y]='B';else {//有地雷就停止遍歷并且改變boardboard[x][y]=(char)( sum+'0');return;}for(int[] d:dir)//繼續遍歷可能的路徑{int nextX=d[0]+x,nextY=d[1]+y;if(nextX<0||nextY>=board[0].length||nextY<0||nextX>=board.length||board[nextX][nextY]!='E') continue;update(board, nextX, nextY, dir);}}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/394177.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/394177.shtml
英文地址,請注明出處:http://en.pswp.cn/news/394177.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

redhat6 刪除mysql_Red Hat enterprise linux 6卸載默認安裝的 mysql

因為Red Hat enterprise linux 6 自帶了一個mysql&#xff0c;所以當你安裝新的mysql時&#xff0c;就會提示錯誤如&#xff1a;error&#xff1a;Failed dependencies&#xff1a;MySQL conflicts with mysql-5.1.47-4.el6.i686rmp -qa mysql 可以看到安裝的mysql于是將自帶的…

swift通知欄推送_如何使用Swift使用推送通知構建食品交付應用

swift通知欄推送by Neo Ighodaro由新Ighodaro 如何使用Swift使用推送通知構建食品交付應用 (How to build a food delivery app with push notifications using Swift) A basic understanding of Swift and Node.js is needed to follow this tutorial.要學習本教程&#xff0…

Jenkins持續集成實踐之java項目自動化部署

關于Linux安裝Jenkins可以參考我的這篇博文Ubuntu16.04環境安裝jenkins 1.安裝部署插件 進入插件管理&#xff0c;并搜索該插件Deploy to container Plugin進行安裝 &#xff0c;下載地址為&#xff1a;https://wiki.jenkins-ci.org/display/JENKINS/DeployPlugin 2.安裝完后&a…

云計算時代企業內部IT人員的新定位

本文講的是云計算時代企業內部IT人員的新定位&#xff0c;【IT168 云計算頻道】漸漸的云計算熱起來&#xff0c;但是怎么去嚴格定義云計算&#xff0c;還是沒有一個統一的說法&#xff0c;最常用的就是舉例子的方式來說什么是云計算&#xff0c;最常用來打比方的是電力&#xf…

Java 多線程 筆記 轉自http://www.cnblogs.com/lwbqqyumidi/p/3804883.html

多線程作為Java中很重要的一個知識點&#xff0c; 一.線程的生命周期及五種基本狀態 關于Java中線程的生命周期&#xff0c;首先看一下下面這張較為經典的圖&#xff1a; 上圖中基本上囊括了Java中多線程各重要知識點。掌握了上圖中的各知識點&#xff0c;Java中的多線程也就基…

leetcode207. 課程表(dfs/bfs)

你這個學期必須選修 numCourse 門課程&#xff0c;記為 0 到 numCourse-1 。 在選修某些課程之前需要一些先修課程。 例如&#xff0c;想要學習課程 0 &#xff0c;你需要先完成課程 1 &#xff0c;我們用一個匹配來表示他們&#xff1a;[0,1] 給定課程總量以及它們的先決條件…

r.java是什么_R.java文件介紹

http://blog.chinaunix.net/uid-21411227-id-4133828.html注意&#xff1a;R.java文件不能手動修改。1. HelloWorld工程中的R.java文件解析package com.android.hellworld;public final class R {public static final class attr {}public static final class drawable {public…

python qt 拖拽組件使用方法_Python QT組件庫qtwidgets的使用

雖然Qt提供了不少現成的組件&#xff0c;但是在Python中使用PyQt5或PySide2進行圖形界面程序開發的過程&#xff0c;還是免不了要根據自己的需求組合一些小部件以形成新的自定義組件。最近州的先生在寫一個桌面圖形界面的登錄密碼框的過程中&#xff0c;發現了這樣一個小巧的自…

get與post區別

兩種 HTTP 請求方法&#xff1a;GET 和 POST 在客戶機和服務器之間進行請求-響應時&#xff0c;兩種最常被用到的方法是&#xff1a;GET 和 POST。 GET - 從指定的資源請求數據。POST - 向指定的資源提交要被處理的數據GET 方法 請注意&#xff0c;查詢字符串&#xff08;名稱/…

java 實現 sql join_Sql 數據庫 join 連接

sql里面有兩個連接一個是union&#xff0c;另一個就是join他們兩個的區別:union 連接的是行 是一行一行的連 而 join 連接的是列(字段) (他們倆的區別暫時就就知道這點)join連接的使用的前提:1.必須要有至少一個表(一個表可以用自連接)2.必須要有相關聯的列(字段)&#xff…

開源與云計算

本文講的是開源與云計算&#xff0c;【IT168 資訊】幾年來我一直擔心開源運動可能會遭受Kim Stanley Robinson在“Green Mars”中精辟論述的問題&#xff1a;“歷史的浪潮比我們做得還要快。”創新者被拋在后面&#xff0c;他們曾經改變的世界拿著他們的主意向著意想不到的方向…

c/c++連接mysql數據庫設置及亂碼問題(vs2013連接mysql數據庫,使用Mysql API操作數據庫)...

我的安裝環境&#xff1a; (1)vs2013(32位版) (vs2013只有32位的 沒有64位的&#xff0c;但是它可以編譯出64位的程序) &#xff1b; (2)mysql-5.7.15(64位) vs2013中的設置&#xff08;按步驟來&#xff0c;順序不要亂&#xff09; (1)首先在vs2013中新建一個控制臺程序 Mysq…

leetcode542. 01 矩陣(bfs/dp)

給定一個由 0 和 1 組成的矩陣&#xff0c;找出每個元素到最近的 0 的距離。 兩個相鄰元素間的距離為 1 。 示例 1: 輸入: 0 0 0 0 1 0 0 0 0 輸出: 0 0 0 0 1 0 0 0 0 bfs代碼 class Solution {int[][] res;public int[][] updateMatrix(int[][] matrix) {int[][] dirnew…

react本地儲存_如何使用React和本地存儲構建freeCodeCamp的配方框

react本地儲存by Edward Njoroge愛德華尼約格(Edward Njoroge) 如何使用React和本地存儲構建freeCodeCamp的配方框 (How to build freeCodeCamp’s recipe box using React and local storage) I completed my first edition of the Free Code Camp recipe box project on May…

調用接口返回500_公交卡余額查詢接口開放使用啦!

API說明本API返回數據僅支持JSON格式且會對中文進 行unicode 編碼&#xff0c;JSON格式返回數據基本格式如下&#xff1a;{"errCode": 0,"errMsg": "OK","data": {}}其中 errCode 表示請求狀態&#xff0c;0表示請求成功&#xff0c; …

stark組件開發之組合搜索基本顯示

數據的獲取&#xff0c;上一篇&#xff0c;已經有了&#xff01;然后就是&#xff0c;如何進行展示的問題。到了展示這里&#xff0c;又有了新的問題&#xff0c; 因為從數據庫&#xff0c;取得的數據。 分為 queryset 和 tuple 兩種數據結構。tuple 中&#xff0c;只是字符串。…

美國安全廠商在云安全上的最新進展

本文講的是美國安全廠商在云安全上的最新進展&#xff0c;【IT168 資訊】優利系統公司日前推出了一系列云產品和服務&#xff0c;并且著重強調企業創建私有云&#xff0c;公有云或混合云工具的安全。  Unisys Secure Cloud是優利系統公司推出的一種管理云服務&#xff0c;承諾…

hessianphp java_hessian 在PHP中的使用

一、hessian是什么&#xff1f;看到這個單詞我還不知道怎么讀&#xff0c;音標是[hes]讀黑森。Hessian是一個輕量級的遠程的數據交換工具&#xff0c;使用簡單的方法提供了RMI(遠程方法調用)的功能. 相比WebService&#xff0c;Hessian更簡單、快捷。采用的是二進制RPC協議&…

leetcode1025. 除數博弈(dp/數學)

愛麗絲和鮑勃一起玩游戲&#xff0c;他們輪流行動。愛麗絲先手開局。 最初&#xff0c;黑板上有一個數字 N 。在每個玩家的回合&#xff0c;玩家需要執行以下操作&#xff1a; 選出任一 x&#xff0c;滿足 0 < x < N 且 N % x 0 。 用 N - x 替換黑板上的數字 N 。 如…

100萬用戶服務器_我的應用在一個月內如何增長超過100萬用戶

100萬用戶服務器by Assaf Elovic通過阿薩夫埃洛維奇 我的應用在一個月內如何增長超過100萬用戶 (How my app grew by over 1M users in one month) 只需要這種簡單的每周方法和耐心。 (All it took was this simple weekly approach and patience.) Building and promoting a …