leetcode-529-掃雷遊戲-c++
阿新 • • 發佈:2018-12-31
思路:點開一個格子時,判斷當前格子是不是雷,是雷的話,把該格子改為'X',然後直接返回。若當前格子不是雷,則先統計周圍有幾個雷,如果旁邊一個雷都沒有,把當前格子改為'B',並遞迴的搜尋其他八個方向的格子。如果旁邊有雷,則把當前格子改為雷的數目,返回。
其中的order表示訪問次序,用來區分是不是一開始就點到了雷。
class Solution { private: void dfs(vector<vector<char>>& board, int i, int j, int& order) { ++order; //越界返回 if (i < 0 || i >= board.size() || j<0 || j>=board[0].size()) return; //挖到雷返回 if (1 == order && board[i][j] == 'M') {//一開始就挖到雷,主過程直接返回 board[i][j] = 'X';//修改為X return; } //如果不是雷 if ('E' == board[i][j]) { int cnt = 0; int iNext[] = { -1,-1,-1,0,0,1,1,1 }; int jNext[] = { -1,0,1,-1,1,-1,0,1 }; for (int k = 0;k < 8;++k) {//數週圍的八個方向的地雷數 int I = i + iNext[k]; int J = j + jNext[k]; if (I>=0&&I<board.size()&&J>=0&&J<board[0].size()&&board[I][J] == 'M') ++cnt; } if (0 == cnt) { board[i][j] = 'B'; for (int k = 0;k < 8;++k) {//遞迴搜尋周圍的八個方向 int I = i + iNext[k]; int J = j + jNext[k]; dfs(board, I, J, order);//如果i,j被改為B,則遞迴搜尋其他位置 } } else { board[i][j] = '0' + cnt;//i,j被改為數字(說明到了邊界),就不再遞迴的搜尋 return; } } } public: vector<vector<char>> updateBoard(vector<vector<char>>& board, vector<int>& click) { int i = click[0]; int j = click[1]; int order = 0; dfs(board, i, j, order); return board; } };