130. Surrounded Regions
130. Surrounded Regions
题目
Given a 2D board containing 'X' and 'O' (the letter 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
解析
-
核心思想:只有边界上'O'的位置组成的片区不会被'X'包围。因此先对边界上的'O'遍历之后暂存为''。非''的'O'即被'X'包围了。
-
此题考查DFS/BFS的思想,就像走迷宫问题,入口和出口位置不同,DFS/BFS的效率不一样,递归式的DFS 会出现stackoverflow 或者run time的问题
-
bug :发现leetcode系统必须检查输入为空的情况!否则出现
"Runtime Error Message:reference binding to null pointer of type 'struct value_type' Last executed input: []
之类的错误!!!
class Solution {
public:
void bfs(vector<vector<char>> &board,int cur_i,int cur_j,int row,int col)
{
if(board[cur_i][cur_j]!='O')
return;
board[cur_i][cur_j]='*';
queue<pair<int, int >> q;
q.push(make_pair(cur_i,cur_j));
while(!q.empty())
{
int i=q.front().first;
int j=q.front().second;
q.pop();
//board[i][j]='*';
if(i-1>=0&&board[i-1][j]=='O')
{
board[i-1][j]='*';
q.push(make_pair(i-1,j));
}
if(i+1<row&& board[i+1][j]=='O') //i+1<=row bug:vector边界溢出,花了很长时间才找到!!!
{
board[i+1][j]='*';
q.push(make_pair(i+1,j));
}
if(j-1>=0&&board[i][j-1]=='O')
{
board[i][j-1]='*';
q.push(make_pair(i,j-1));
}
if(j+1<col&&board[i][j+1]=='O') //j+1<=col
{
board[i][j+1]='*';
q.push(make_pair(i,j+1));
}
}
}
void solve(vector<vector<char>> &board) {
//bfs
if (board.empty()) //bug :发现leetcode系统必须检查输入为空的情况!
return;
int row=board.size();
int col=board[0].size();
if(row==0||col==0)
return;
for(int i=0;i<row;i++)
{
if(board[i][0]=='O')
bfs(board,i,0,row,col);
if(board[i][col-1]=='O')
bfs(board,i,col-1,row,col);
}
for(int j=0;j<col;j++)
{
if(board[0][j]=='O')
bfs(board,0,j,row,col);
if(board[row-1][j]=='O')
bfs(board,row-1,j,row,col);
}
for(int i=0;i<row;i++)
for(int j=0;j<col;j++)
{
board[i][j]= (board[i][j]=='*')?'O':'X';
}
}
};
- 这样考虑时间复杂度
for(int i=0;i<row;i++)
for(int j=0;j<col;j++) //直接也有复杂度的问题
{
if(board[i][j]=='O')
{
if(i==0||i==row-1||j==0||j==col-1)
{
bfs(board,i,j,row,col); //广度优先搜索使用队列
}
}
}
题目来源
C/C++基本语法学习
STL
C++ primer
分类:
leetcode
标签:
递归+DFS+BFS+回溯
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
· 一个超经典 WinForm,WPF 卡死问题的终极反思
· ASP.NET Core - 日志记录系统(二)
· 支付宝事故这事儿,凭什么又是程序员背锅?有没有可能是这样的...
· https证书一键自动续期,帮你解放90天限制
· 在线客服系统 QPS 突破 240/秒,连接数突破 4000,日请求数接近1000万次,.NET 多
· 推荐几个不错的 Linux 服务器管理工具
· C# 开发工具Visual Studio 介绍
2016-12-30 机器学习算法盘点