码迷,mamicode.com
首页 > 其他好文 > 详细

【leetcode】Surrounded Regions

时间:2015-01-21 22:17:26      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:

Surrounded Regions

Given a 2D board containing ‘X‘ and ‘O‘, capture all regions surrounded by ‘X‘.

A region is captured by flipping all ‘O‘s into ‘X‘s in that surrounded region.

For example,

X X X X
X O O X
X X O X
X O X X

After running your function, the board should be:

X X X X
X X X X
X X X X
X O X X
 
 
用dfs试试,大数据时递归会溢出
 1 class Solution {
 2 public:
 3     void solve(vector<vector<char>> &board) {
 4         int m=board.size();
 5         if(m==0) return;
 6         int n=board[0].size();
 7        
 8         vector<vector<bool>> visited(m,vector<bool>(n,false));
 9         for(int i=0;i<m;i++)
10         {
11             if(board[i][0]==O&&!visited[i][0])
12             {
13                 dfs(board,visited,i,0,m,n);
14             }
15            
16             if(board[i][n-1]==O&&!visited[i][n-1])
17             {
18                 dfs(board,visited,i,n-1,m,n);
19             }
20         }
21        
22         for(int j=0;j<n;j++)
23         {
24            
25             if(board[0][j]==O&&!visited[0][j])
26             {
27                 dfs(board,visited,0,j,m,n);
28             }
29            
30             if(board[m-1][j]==O&&!visited[m-1][j])
31             {
32                 dfs(board,visited,m-1,j,m,n);
33             }
34            
35         }
36        
37        
38         for(int i=0;i<m;i++)
39         {
40             for(int j=0;j<n;j++)
41             {
42                 if(board[i][j]==O&&visited[i][j])
43                 {
44                     board[i][j]=X;
45                 }
46             }
47         }
48        
49         return;
50     }
51    
52     void dfs(vector<vector<char>> &board,vector<vector<bool>> &visited,int i,int j,int &m,int &n)
53     {
54         if(board[i][j]==O)
55         {
56             visited[i][j]=true;
57             if(i+1<m&&visited[i+1][j]==false)dfs(board,visited,i+1,j,m,n);
58             if(j+1<n&&visited[i][j+1]==false)dfs(board,visited,i,j+1,m,n);
59             if(i-1>=0&&visited[i-1][j]==false)dfs(board,visited,i-1,j,m,n);
60             if(j-1>=0&&visited[i][j-1]==false)dfs(board,visited,i,j-1,m,n);
61         }
62         else
63         {
64             return;
65         }
66     }       
67 };

 

利用广度优先搜索,先把边界上的O全部放到队列中,然后搜索
 
 1 class Solution {
 2 public:
 3     void solve(vector<vector<char>> &board) {
 4         int m=board.size();
 5         if(m==0) return;
 6         int n=board[0].size();
 7        
 8         queue<pair<int,int>> q;
 9        
10         vector<vector<bool>> visited(m,vector<bool>(n,false));
11         for(int i=0;i<m;i++)
12         {
13             if(board[i][0]==O) q.push(pair<int,int>(i,0));
14             if(board[i][n-1]==O)  q.push(pair<int,int>(i,n-1));
15         }
16        
17         for(int j=0;j<n;j++)
18         {
19             if(board[0][j]==O)  q.push(pair<int,int>(0,j));
20             if(board[m-1][j]==O)  q.push(pair<int,int>(m-1,j));
21         }
22        
23         bfs(q,board,visited,m,n);
24        
25         for(int i=0;i<m;i++)
26         {
27             for(int j=0;j<n;j++)
28             {
29                 if(!visited[i][j]&&board[i][j]==O)  board[i][j]=X;
30             }
31         }
32     }
33    
34    
35     void bfs(queue<pair<int,int>> &q,vector<vector<char>> &board,vector<vector<bool>> &visited,int &m,int &n)
36     {
37         while(!q.empty())
38         {
39             int ii=q.front().first;
40             int jj=q.front().second;
41             visited[ii][jj]=true;
42                    
43             q.pop();
44                    
45             if(ii+1<m&&!visited[ii+1][jj]&&board[ii+1][jj]==O) q.push(pair<int,int>(ii+1,jj));
46             if(ii-1>=0&&!visited[ii-1][jj]&&board[ii-1][jj]==O) q.push(pair<int,int>(ii-1,jj));
47             if(jj+1<n&&!visited[ii][jj+1]&&board[ii][jj+1]==O) q.push(pair<int,int>(ii,jj+1));
48             if(jj-1>=0&&!visited[ii][jj-1]&&board[ii][jj-1]==O) q.push(pair<int,int>(ii,jj-1));
49         }
50     }
51 };

 

【leetcode】Surrounded Regions

标签:

原文地址:http://www.cnblogs.com/reachteam/p/4240014.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!