算法训练营day66-孤岛总面积-沉没孤岛-水流问题-建造最大岛屿

题目1:101. 孤岛的总面积 (kamacoder.com)

复制代码
#include <iostream>
#include <vector>
#include <queue>
using namespace std;
int dir[4][2] = {0,-1,-1,0,0,1,1,0};
int count = 0;
void bfs(vector<vector<int>>& map, vector<vector<bool>>& vistied, int x, int y, bool flag) {
    queue<pair<int, int>> qu;
    qu.push(pair<int, int>(x, y));
    vistied[x][y] = true;
    if(flag) map[x][y] = 0;
    else count++;
    while(!qu.empty()) {
        pair<int, int> cur = qu.front();
        qu.pop();
        int newx = cur.first;
        int newy = cur.second;
        for(int i = 0;i < 4;i++) {
            int nextx = newx + dir[i][0];
            int nexty = newy + dir[i][1];
            if(nextx < 0 || nextx >= map.size() || nexty < 0 || nexty >= map[0].size()) continue;
            if(!vistied[nextx][nexty] && map[nextx][nexty] == 1) {
                vistied[nextx][nexty] = true;
                qu.push(pair<int, int>(nextx, nexty));
                if(flag) map[nextx][nexty] = 0;
                else count++;
            }
        }
    }
}

int main() {
    int n,m;
    cin >> n >> m;
    vector<vector<int>> map(n, vector<int>(m));
    for(int i = 0;i < n;i++) {
        for(int j = 0;j < m;j++) {
            cin >> map[i][j]; 
        }
    }
    
    vector<vector<bool>> vistied(n, vector<bool>(m, false));
    for(int j = 0;j < m;j++) {
        if(map[0][j] == 1 && !vistied[0][j]) bfs(map, vistied, 0, j, true);
        if(map[n - 1][j] == 1 && !vistied[n - 1][j]) bfs(map, vistied, n - 1, j, true);
    }
    for(int i = 0;i < n;i++) {
        if(map[i][0] == 1 && !vistied[i][0]) bfs(map, vistied, i, 0, true);
        if(map[i][m - 1] == 1 && !vistied[i][m - 1]) bfs(map, vistied, i, m - 1, true);
    }

    for(int i = 0;i < n;i++) {
        for(int j = 0;j < m;j++) {
            if(!vistied[i][j] && map[i][j] == 1) {
                // if(i != 0 && i != n - 1 && j != 0 && j != m - 1) {
                //     result++;
                // }
                bfs(map,vistied,i,j, false);
            }
        }
    }
    cout << count << endl;
    return 0;
}

题目2:102. 沉没孤岛 (kamacoder.com)

复制代码
#include <iostream>
#include <vector>
#include <queue>
using namespace std;
int dir[4][2] = {0,-1,-1,0,0,1,1,0};

void bfs(vector<vector<int>>& map, vector<vector<bool>>& vistied, vector<vector<int>>& result, int x, int y, bool flag) {
    queue<pair<int, int>> qu;
    qu.push(pair<int, int>(x, y));
    vistied[x][y] = true;
    if(flag) map[x][y] = 0;
    else result[x][y] = 0;
    while(!qu.empty()) {
        pair<int, int> cur = qu.front();
        qu.pop();
        int newx = cur.first;
        int newy = cur.second;
        for(int i = 0;i < 4;i++) {
            int nextx = newx + dir[i][0];
            int nexty = newy + dir[i][1];
            if(nextx < 0 || nextx >= map.size() || nexty < 0 || nexty >= map[0].size()) continue;
            if(!vistied[nextx][nexty] && map[nextx][nexty] == 1) {
                vistied[nextx][nexty] = true;
                qu.push(pair<int, int>(nextx, nexty));
                if(flag) map[nextx][nexty] = 0;
                else result[nextx][nexty] = 0;
            }
        }
    }
}

int main() {
    int n,m;
    cin >> n >> m;
    vector<vector<int>> map(n, vector<int>(m));
    vector<vector<int>> result(n, vector<int>(m));
    for(int i = 0;i < n;i++) {
        for(int j = 0;j < m;j++) {
            cin >> map[i][j];
            result[i][j] = map[i][j];
        }
    }
    
    vector<vector<bool>> vistied(n, vector<bool>(m, false));
    for(int j = 0;j < m;j++) {
        if(map[0][j] == 1 && !vistied[0][j]) bfs(map, vistied, result, 0, j, true);
        if(map[n - 1][j] == 1 && !vistied[n - 1][j]) bfs(map, vistied, result, n - 1, j, true);
    }
    for(int i = 0;i < n;i++) {
        if(map[i][0] == 1 && !vistied[i][0]) bfs(map, vistied, result, i, 0, true);
        if(map[i][m - 1] == 1 && !vistied[i][m - 1]) bfs(map, vistied, result, i, m - 1, true);
    }

    for(int i = 0;i < n;i++) {
        for(int j = 0;j < m;j++) {
            if(!vistied[i][j] && map[i][j] == 1) {
                bfs(map,vistied, result,i,j, false);
            }
        }
    }
    for(int i = 0;i < n;i++) {
        for(int j = 0;j < m - 1;j++) {
             cout << result[i][j] << ' ';
        }
        cout << result[i][m - 1] << endl;
    }
   
    return 0;
}

题目3:103. 水流问题 (kamacoder.com)

题目4:104. 建造最大岛屿 (kamacoder.com)

相关推荐
TheLegendMe11 小时前
贪心+线程安全单例
算法·哈希算法
豐儀麟阁贵11 小时前
8.5在方法中抛出异常
java·开发语言·前端·算法
胖咕噜的稞达鸭11 小时前
算法入门:滑动窗口--->找到字符串中所有的字母异位词,串联所有的子串,最小覆盖子串
数据库·redis·算法
小青龙emmm12 小时前
2025级C语言第二次周测(国教专用)题解
c语言·开发语言·算法
WolfGang00732112 小时前
代码随想录算法训练营Day28 | 509.斐波那契数列、70.爬楼梯、746.使用最小花费爬楼梯
算法
Boop_wu12 小时前
[Java EE] 多线程进阶(JUC)(2)
java·jvm·算法
闻缺陷则喜何志丹13 小时前
【SOSDP模板 容斥原理 逆向思考】3757. 有效子序列的数量|分数未知
c++·算法·力扣·容斥原理·sosdp·逆向思考
CoovallyAIHub13 小时前
如何在手机上轻松识别多种鸟类?我们发现了更简单的秘密……
深度学习·算法·计算机视觉
第二只羽毛13 小时前
遵守robots协议的友好爬虫
大数据·爬虫·python·算法·网络爬虫
艾斯比的日常14 小时前
Java 三色标记算法:并发垃圾回收的核心技术解析
java·开发语言·算法