您的位置:首页 > 房产 > 建筑 > 有没有免费的直播视频下载_电脑上必玩的游戏_网站推广软文范例_最好的免费信息发布平台

有没有免费的直播视频下载_电脑上必玩的游戏_网站推广软文范例_最好的免费信息发布平台

2025/1/15 8:28:44 来源:https://blog.csdn.net/qq_53524614/article/details/142852718  浏览:    关键词:有没有免费的直播视频下载_电脑上必玩的游戏_网站推广软文范例_最好的免费信息发布平台
有没有免费的直播视频下载_电脑上必玩的游戏_网站推广软文范例_最好的免费信息发布平台

106. 岛屿的周长

#include<bits/stdc++.h>
using namespace std;int main(){int n, m;cin >> n >> m;vector<vector<int>> mp(n, vector<int>(m, 0));for (int i = 0; i < n; i++){for (int j = 0; j < m; j++){cin >> mp[i][j];}}int landNum = 0;int neighborNum = 0;for (int i = 0; i < n; i++){for (int j = 0; j < m; j++){if (mp[i][j] == 1){landNum++;if (i < n - 1){if (mp[i + 1][j] == 1) neighborNum++;}if (j < m - 1){if (mp[i][j + 1] == 1) neighborNum++;}}}}cout << (4 * landNum - 2 * neighborNum);return 0;
}

这题没必要用图的遍历算法,直接遍历一遍更加简单,且时间复杂度差不多,不过也还是可以有巧思。笔者更喜欢随想录所提的第二种算法,一个陆地有4条边,如果与别的陆地相邻,那就有两条陆地的边不是岛的边缘,所以遍历中只需要关注陆地的数量,以及陆地的邻接数量就可以轻松的得到答案,也就是4 * landNum - 2 * neighborNum

代码随想录 106. 岛屿的周长

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com