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

乡镇美丽乡村建设网站信息谷歌浏览器下载手机版安卓官网

乡镇美丽乡村建设网站信息,谷歌浏览器下载手机版安卓官网,兔展h5制作,如何创建自己的网页一、图论问题 Ⅱ 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.dtcms.com/wzjs/276334.html

相关文章:

  • 张家港网站制作公司数据推广公司
  • 做网站一定要正版系统吗整站快速排名
  • 福州网站关键词的搜索引擎优化
  • 好分数的开发公司网站建设公司seo关键词
  • app网站建设宣传方案投广告哪个平台好
  • 选择电商网站建设奉化seo页面优化外包
  • 昆山网站建设培训班外链发布平台有哪些
  • 珠海响应式网站建设公司深圳网站建设服务
  • 自己能建设网站网络优化工作内容
  • 我做的网站上有需要别人直接下载的东西 怎么做到这一步百度收录时间
  • asp网站制作教程企业网页
  • 如何学习制作网站个人网站模板建站
  • 汉口网站制作南京seo外包
  • wordpress 插件上传seo咨询价格找推推蛙
  • wordpress 网站变慢seo社区
  • wordpress接erp网站优化排名方法有哪些
  • 国外做meta分析的网站竞价托管选择微竞价
  • 重庆做网站建设的公司推广一款app的营销方案
  • 夏津网站开发青岛推广优化
  • wordpress主页导航谷歌seo网站运营
  • 手机模板网站模板下载工具浙江网站建设营销
  • 网站建设公司合同模板石家庄网站建设方案
  • 电子商务seo名词解释夫唯seo教程
  • 个旧网站建设网络营销相关的岗位有哪些
  • 平面设计教程网站有哪些网络营销策划书怎么写
  • 中联建设集团网站成都短视频代运营
  • 网站报价单模板搜索排行
  • gogogo高清在线观看视频百度seo优化分析
  • 铁威马 Nas 做网站电脑培训学校能学什么
  • 笔记本可以做网站吗网络营销案例分析题及答案