当前位置: 首页 > news >正文

梧州网站优化7月新闻大事件30条

梧州网站优化,7月新闻大事件30条,wordpress图床推荐,app开发和网站开发价格Leetcode 1254 题意 给定一个m*n的矩阵含有0和1,1代表水,0代表陆地,岛屿是陆地的集合,如果一个岛屿和四个方向的边界相连,则不算封闭岛屿。求有多少个封闭的岛屿。 题目链接 https://leetcode.com/problems/number…

Leetcode 1254

题意

给定一个m*n的矩阵含有0和1,1代表水,0代表陆地,岛屿是陆地的集合,如果一个岛屿和四个方向的边界相连,则不算封闭岛屿。求有多少个封闭的岛屿。

题目链接

https://leetcode.com/problems/number-of-closed-islands/

思路

从边界上的0开始用dfs向四个方向遍历,把这些0形成的岛屿都遍历完成,这样就能排除和边界相连的岛屿。然后再从没有遍历过的0开始用dfs向四个方向遍历,并且计数。这些岛屿就是封闭的岛屿(参考number of islands)

题解

class Solution {
public:int m;int n;int closedIsland(vector<vector<int>>& grid) {m = grid.size();n = grid[0].size();int res = 0;vector<vector<bool>> vis(m, vector<bool>(n, false));for(int i = 0; i < m; i++) {if(grid[i][0] == 0 && !vis[i][0]) {dfs(grid, vis, i, 0);}if(grid[i][n-1] == 0 && !vis[i][n-1]) {dfs(grid, vis, i, n-1);}}for(int i = 0; i < n; i++) {if(grid[0][i] == 0 && !vis[0][i]) {dfs(grid, vis, 0, i);}if(grid[m-1][i] == 0 && !vis[m-1][i]) {dfs(grid, vis, m-1, i);}}for(int i = 0; i < m; i++) {for(int j = 0; j < n; j++) {if(grid[i][j] == 0 && !vis[i][j]) {dfs(grid, vis, i, j);res++;}}}return res;}void dfs(vector<vector<int>>& grid, vector<vector<bool>>& vis, int x, int y) {vis[x][y] = true;int dk[] = {-1, 0, 1, 0, -1};for(int i = 0; i < 4; i++) {int dx = x + dk[i];int dy = y + dk[i+1];if(dx >= 0 && dx < m && dy >= 0 && dy < n && !vis[dx][dy] && grid[dx][dy] == 0) {dfs(grid, vis, dx, dy);}}}
};

时间复杂度: O ( m n ) O(mn) O(mn) m为给定矩阵的长度,n为给定矩阵的宽度
空间复杂度: O ( m n ) O(mn) O(mn) m为给定矩阵的长度,n为给定矩阵的宽度

Leetcode 1020

思路

和Leetcode 1254一样,只是换壳的Number of Closed Islands + Max Area of Island,不赘述了。

题解

class Solution {
public:int m;int n;int numEnclaves(vector<vector<int>>& grid) {m = grid.size();n = grid[0].size();int res = 0;vector<vector<bool>> vis(m, vector<bool>(n, false));for(int i = 0; i < m; i++) {if(grid[i][0] == 1 && !vis[i][0]) {dfs(grid, vis, i, 0);}if(grid[i][n-1] == 1 && !vis[i][n-1]) {dfs(grid, vis, i, n-1);}}for(int i = 0; i < n; i++) {if(grid[0][i] == 1 && !vis[0][i]) {dfs(grid, vis, 0, i);}if(grid[m-1][i] == 1 && !vis[m-1][i]) {dfs(grid, vis, m-1, i);}}for(int i = 0; i < m; i++) {for(int j = 0; j < n; j++) {if(grid[i][j] == 1 && !vis[i][j]) {res += dfs(grid, vis, i, j);}}}return res;}int dfs(vector<vector<int>>& grid, vector<vector<bool>>& vis, int x, int y) {vis[x][y] = true;int area = 1;int dk[] = {-1, 0, 1, 0, -1};for(int i = 0; i < 4; i++) {int dx = x + dk[i];int dy = y + dk[i+1];if(dx >= 0 && dx < m && dy >= 0 && dy < n && grid[dx][dy] == 1 && !vis[dx][dy]) {area += dfs(grid, vis, dx, dy);}}return area;}
};

时间复杂度: O ( m n ) O(mn) O(mn) m为给定矩阵的长度,n为给定矩阵的宽度
空间复杂度: O ( m n ) O(mn) O(mn) m为给定矩阵的长度,n为给定矩阵的宽度

http://www.tj-hxxt.cn/news/65948.html

相关文章:

  • 设计师招聘网站口碑营销属于什么营销
  • 网络营销推广系统排名推荐系统精准网站seo诊断报告
  • 南宁哪个公司做网站好郑州网络推广服务
  • 百度收录不到公司网站公司网站免费建站
  • 广州专业网站制作哪家专业网站建设与管理就业前景
  • 厦门外贸网站建设平台营销
  • 怎样给网站做 站内搜索推广软件的渠道有哪些
  • 世界营销大师排名大型seo公司
  • 莘县制作网站网络营销产品的首选产品
  • 网络开发工程师工资肇庆网站快速排名优化
  • 生活信息网站建设北京专门做seo
  • 百度推广 做网站竞价托管就选微竞价
  • 上海什么做网站的公司比较好北京搜索引擎优化管理专员
  • 简洁大气的公司网站如何设计企业网站
  • 聊天室网站开发外包公司为什么没人去
  • 永嘉专业网站建设团队中国十大门户网站排行
  • 做任务赚佣金的网站seo公司排名
  • wordpress资讯网站模板潍坊关键词优化排名
  • 国内设计师交流网站百度大搜推广和百度竞价
  • 网站建设成立领导小组新网站怎么做优化
  • 太原疫情防控最新政策seo推广方法有哪些
  • 网站开发建设类合同百度应用市场下载安装
  • 找人做网站怎么找自动发外链工具
  • 网站开发 绩效考核怎么做网络营销推广
  • 广东建设网站互联网全网营销
  • 湖南高端网站制作公司怎样在百度上做广告推广
  • 需要注册的网站建设海外广告联盟平台推广
  • 龙岩网站建设teams熊掌号拼多多关键词排名查询
  • 中山网站建设搭建网站品牌推广公司
  • 网站域名续费怎么续费关键词排名优化