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

制作快递网站/手机自己怎么建电影网站

制作快递网站,手机自己怎么建电影网站,南充免费推广网站,极验 wordpress 表单一、图论问题 Ⅱ 1、岛屿的最大面积 这题和上一篇博客求岛屿数量如出一辙&#xff0c;都是要找出所有岛屿&#xff0c;深度优先搜索代码如下&#xff1a; # include<iostream> # include<vector>using namespace std;int dfs(vector<vector<int>> …

一、图论问题 Ⅱ

1、岛屿的最大面积

这题和上一篇博客求岛屿数量如出一辙,都是要找出所有岛屿,深度优先搜索代码如下:

# include<iostream>
# include<vector>using namespace std;int dfs(vector<vector<int>> &graph, int i, int j){if(i<0 || i>=graph.size() || j<0 || j>=graph[0].size() || graph[i][j]!=1)return 0;graph[i][j] = 2;return 1 + dfs(graph, i+1, j)+ dfs(graph, i-1, j)+ dfs(graph, i, j+1)+ dfs(graph, i, j-1);
}int main(){int n, m;cin >> n >> m;vector<vector<int>> graph(n, vector<int>(m));for(int i=0; i<n; ++i)for(int j=0; j<m; ++j)cin >> graph[i][j];int ans = 0;for(int i=0; i<n; ++i)for(int j=0; j<m; ++j)if(graph[i][j]==1)ans = max(ans, dfs(graph, i, j));cout << ans << endl;return 0;
}

广度优先搜索代码如下:

# include<iostream>
# include<vector>
#include<queue>using namespace std;vector<vector<int>> dirs({{0, 1}, {0, -1}, {1, 0}, {-1, 0}});
int bfs(vector<vector<int>> &graph, int ii, int jj){queue<pair<int, int>> q;q.push({ii, jj});graph[ii][jj] = 2;int res = 0;while(!q.empty()){auto cur = q.front(); q.pop();++res;for(auto xy : dirs){int i = cur.first + xy[0], j = cur.second + xy[1];if(i<0 || i>=graph.size() || j<0 || j>=graph[0].size() || graph[i][j]!=1)continue;graph[i][j] = 2;q.push({i, j});}}return res;
}int main(){int n, m;cin >> n >> m;vector<vector<int>> graph(n, vector<int>(m));for(int i=0; i<n; ++i)for(int j=0; j<m; ++j)cin >> graph[i][j];int ans = 0;for(int i=0; i<n; ++i)for(int j=0; j<m; ++j)if(graph[i][j]==1)ans = max(ans, bfs(graph, i, j));cout << ans << endl;return 0;
}

2、孤岛总面积

本质上还是要搜索所有岛屿,同时还得统计岛屿面积,将是孤岛的面积累加。这就涉及到不是孤岛的判断,遇到边界就不是孤岛,这个不要加入结果,我们只需要让函数的统计结果减去一个很大的数,从而保证不是孤岛的返回值是负数就好,最后结果只累加正数。这个能在之前的代码下做出最小的改动。
深度优先搜索代码如下:

# include<iostream>
# include<vector>using namespace std;int dfs(vector<vector<int>> &graph, int i, int j){if(i<0 || i>=graph.size() || j<0 || j>=graph[0].size() || graph[i][j]!=1)return 0;graph[i][j] = 2;int res = 1;if(i==0 || j==0 || i==graph.size()-1 || j==graph[0].size()-1)res -= 10000;res += dfs(graph, i+1, j)+ dfs(graph, i-1, j)+ dfs(graph, i, j+1)+ dfs(graph, i, j-1);return res;
}int main(){int n, m;cin >> n >> m;vector<vector<int>> graph(n, vector<int>(m));for(int i=0; i<n; ++i)for(int j=0; j<m; ++j)cin >> graph[i][j];int ans = 0;for(int i=0; i<n; ++i)for(int j=0; j<m; ++j)if(graph[i][j]==1)ans += max(0, dfs(graph, i, j));cout << ans << endl;return 0;
}

广度优先搜索代码如下:

# include<iostream>
# include<vector>
#include<queue>using namespace std;vector<vector<int>> dirs({{0, 1}, {0, -1}, {1, 0}, {-1, 0}});
int bfs(vector<vector<int>> &graph, int ii, int jj){queue<pair<int, int>> q;q.push({ii, jj});graph[ii][jj] = 2;int res = 0;while(!q.empty()){auto cur = q.front(); q.pop();++res;if(cur.first==0 || cur.second==0 || cur.first==graph.size()-1 || cur.second==graph[0].size()-1)res -= 10000;for(auto xy : dirs){int i = cur.first + xy[0], j = cur.second + xy[1];if(i<0 || i>=graph.size() || j<0 || j>=graph[0].size() || graph[i][j]!=1)continue;graph[i][j] = 2;q.push({i, j});}}return res;
}int main(){int n, m;cin >> n >> m;vector<vector<int>> graph(n, vector<int>(m));for(int i=0; i<n; ++i)for(int j=0; j<m; ++j)cin >> graph[i][j];int ans = 0;for(int i=0; i<n; ++i)for(int j=0; j<m; ++j)if(graph[i][j]==1)ans += max(0, bfs(graph, i, j));cout << ans << endl;return 0;
}
http://www.lryc.cn/news/577948.html

相关文章:

  • 15个html5手机网站模板/seo营销方法
  • 成绩查询网站开发/如何快速推广一个新产品
  • 注册服务器网站哪个好/如何在百度上添加自己的店铺
  • 深圳做网站/在线crm网站
  • 洛阳做网站的/百度公司地址
  • 做我女朋友程序网站/网站推广排名服务
  • 网站详情页用哪个软件做/挖掘关键词的工具
  • 石家庄网站建设seo优化营销/软文代写价格
  • 宁波网站建设培训/seo关键词挖掘
  • 自动发文章到WordPress/网络seo是什么工作
  • wordpress如何查看网站日记/搜索热词排行榜
  • 泉州网站关键词排名/泰安网站建设
  • 网站建设与维护期末试卷/百度在线客服问答
  • 徐水网站建设/网站制作培训
  • 怎么在中国移动做网站备案/百度ai人工智能
  • 江西南昌网站建设公司哪家好/seo和sem推广
  • 淮南网云小镇房价/手机网站关键词seo
  • 中小企业网站该怎么做/品牌推广的具体方法
  • 北京企业建设网站/今日国际军事新闻最新消息
  • 淮南做网站/长沙靠谱关键词优化服务
  • 如何防止网站攻击/成都建设网官网
  • 用空间做网站如何做好安全/推广营销app
  • 蚌埠网站开发外包/学生个人网页制作教程
  • 搜索别人的网站是带logo的请问怎么做的/北京百度seo排名
  • 社交网站开发语言/临沂森工木业有限公司
  • 网站用户后台是怎么做的/网络推广方案范文
  • 互联网网站建设价格/黑科技引流软件是真的吗
  • 建设我们的网站 教案/手机助手
  • 做网站要注意哪些/销售网络平台
  • 有用node.js做的网站吗/竞价托管一般多少钱