ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Leetcode-5040 Coloring A Border(边框着色)

2019-04-28 14:44:28  阅读:501  来源: 互联网

标签:Coloring r0 int vis grid c0 Border Leetcode color


 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 };

 

标签:Coloring,r0,int,vis,grid,c0,Border,Leetcode,color
来源: https://www.cnblogs.com/Asurudo/p/10783833.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有