图论第三天

似乎要团建了,我再猫会。我必须参与上团建再走。

130.被围绕的区域

先把外围的O变成A,再把飞地的O变成X,再把外围A变回O

cpp 复制代码
class Solution {
public:
    int neighbor[4][2] ={1,0,0,-1,-1,0,0,1};
    void solve(vector<vector<char>>& board) {
        queue<pair<int,int>>que;
        int n = board.size();
        int m = board[0].size();
        for(int i = 0;i < n;i++){
            if(board[i][0] == 'O')bfs(board,que,i,0,'O','A');
            if(board[i][m-1] == 'O')bfs(board,que,i,m-1,'O','A');
        }
        for(int j = 0;j < m;j++){
            if(board[0][j] == 'O')bfs(board,que,0,j,'O','A');
            if(board[n-1][j] == 'O')bfs(board,que,n-1,j,'O','A');
        }
        for(int i = 0;i < n;i++){
            for(int j = 0;j < m;j++){
                if(board[i][j] == 'O')bfs(board,que,i,j,'O','X');
            }
        }
        for(int i = 0;i < n;i++){
            for(int j = 0;j < m;j++){
                if(board[i][j] == 'A')bfs(board,que,i,j,'A','O');
            }
        }
    }
    void bfs(vector<vector<char>>& board,queue<pair<int,int>>que,int x,int y,char X,char Y){
        que.push({x,y});
        board[x][y] = Y;
        while(!que.empty()){
            pair<int,int>cur = que.front();
            que.pop();
            for(int i = 0;i< 4;i++){
                int nextx = cur.first + neighbor[i][0];
                int nexty = cur.second + neighbor[i][1];
                if(nextx < 0 || nexty < 0 || nextx >= board.size() ||nexty >= board[0].size())continue;
                if(board[nextx][nexty] == X){
                    board[nextx][nexty] = Y;
                    que.push({nextx,nexty});
                }
            }

        }
    }
};

417. 太平洋大西洋水流问题

思路:从两边溯流而上。

对不起!!歇一晚上。明天补上。

相关推荐
PhotonixBay5 分钟前
共聚焦显微镜的结构组成与应用
人工智能·算法·机器学习
逆境不可逃13 分钟前
LeetCode 热题 100 之 33. 搜索旋转排序数组 153. 寻找旋转排序数组中的最小值 4. 寻找两个正序数组的中位数
java·开发语言·数据结构·算法·leetcode·职场和发展
tankeven17 分钟前
HJ137 乘之
c++·算法
add45a1 小时前
C++中的观察者模式
开发语言·c++·算法
进击的小头1 小时前
第13篇:基于伯德图的超前_滞后校正器深度设计
python·算法
leaves falling1 小时前
二分查找:迭代与递归实现全解析
数据结构·算法·leetcode
做怪小疯子1 小时前
Leetcode刷题——深度优先搜索(DFS)
算法·leetcode·深度优先
大数据AI人工智能培训专家培训讲师叶梓1 小时前
120B 数学语料 + GRPO 算法,DeepSeekMath 刷新开源大模型推理天花板
人工智能·算法·大模型·推理·deepseek·openclaw·openclaw 讲师
IMPYLH1 小时前
Linux 的 comm 命令
linux·运维·算法
薛定谔的悦1 小时前
嵌入式设备OTA升级实战:从MQTT命令到自动重启的全流程解析
linux·算法·ota·ems