1. 程式人生 > >leetcode-529-掃雷遊戲-c++

leetcode-529-掃雷遊戲-c++

思路:點開一個格子時,判斷當前格子是不是雷,是雷的話,把該格子改為'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; 
    }
};