zoukankan      html  css  js  c++  java
  • Leetcode-5040 Coloring A Border(边框着色)

     1 const int dx[] = {1,-1,0,0};
     2 const int dy[] = {0,0,1,-1};
     3 #define _for(i,a,b) for(int i = (a);i < (b);i ++)
     4 class Solution
     5 {
     6     public:
     7         int vis[60][60];
     8         void go(vector<vector<int>>& grid, int r0, int c0, int color,int lo)
     9         {
    10             vis[r0][c0] = 1;
    11             grid[r0][c0] = -color;
    12             _for(i,0,4)
    13             {
    14                 int nx = r0 + dx[i];
    15                 int ny = c0 + dy[i];
    16                 if(nx>=0 && nx<grid.size() && ny>=0 && ny<grid[0].size()
    17                 && vis[nx][ny]==0 && grid[nx][ny]==lo)
    18                 {
    19                     go(grid,nx,ny,color,lo);
    20                 }
    21             }
    22         }
    23         vector<vector<int>> colorBorder(vector<vector<int>>& grid, int r0, int c0, int color)
    24         {
    25             memset(vis,0,sizeof(vis));
    26             int lo = grid[r0][c0];
    27             go(grid,r0,c0,color,lo);
    28             vector<pair<int,int>> vv;
    29             _for(i,0,grid.size())
    30                 _for(j,0,grid[i].size())
    31                     if(grid[i][j]<0)
    32                     {
    33                         if(i==0 || i==grid.size()-1 || j==0 || j==grid[i].size()-1)
    34                             continue;
    35                         if(grid[i+1][j]==-color && grid[i-1][j]==-color && grid[i][j+1]==-color && grid[i][j-1]==-color)
    36                             vv.push_back({i,j});
    37                       //      grid[i][j] = lo;
    38                     }
    39             _for(i,0,vv.size())
    40                 grid[vv[i].first][vv[i].second] = lo;
    41             _for(i,0,grid.size())
    42                 _for(j,0,grid[i].size())
    43             {
    44                 if(grid[i][j]<0)
    45                     grid[i][j] = -grid[i][j];
    46             }
    47             
    48             return grid;
    49         }
    50 };
  • 相关阅读:
    JVM-对象的创建
    maven依赖无法下载依赖包,PKIX认证不通过
    Object里面的方法
    Java多线程之volatile与synchronized比较
    java 二叉树的创建 遍历
    设计模式之单例模式
    博客园自定义主题 皮肤
    mysql索引 b+树
    sleep和wait的区别(转)
    final/finally/finalize的区别(转)
  • 原文地址:https://www.cnblogs.com/Asurudo/p/10783833.html
Copyright © 2011-2022 走看看