BFS回溯 - 孤立集群的情况
创始人
2024-12-01 02:30:45
0

以下是使用BFS回溯算法解决孤立集群问题的示例代码:

def bfs_backtrack(grid, visited, i, j):
    # 定义四个方向的行列偏移量
    directions = [(-1, 0), (1, 0), (0, -1), (0, 1)]
    # 标记当前节点为已访问
    visited[i][j] = True
    # 使用队列来进行BFS遍历
    queue = [(i, j)]
    while queue:
        x, y = queue.pop(0)
        for dx, dy in directions:
            nx, ny = x + dx, y + dy
            # 判断新的位置是否在合法范围内,并且是孤立集群中的节点
            if 0 <= nx < len(grid) and 0 <= ny < len(grid[0]) and grid[nx][ny] == 1 and not visited[nx][ny]:
                # 标记新节点为已访问
                visited[nx][ny] = True
                # 将新节点加入队列
                queue.append((nx, ny))

def count_islands(grid):
    if not grid or not grid[0]:
        return 0
    m, n = len(grid), len(grid[0])
    visited = [[False] * n for _ in range(m)]
    count = 0
    for i in range(m):
        for j in range(n):
            if grid[i][j] == 1 and not visited[i][j]:
                bfs_backtrack(grid, visited, i, j)
                count += 1
    return count

使用示例:

grid = [
    [1, 1, 0, 0, 0],
    [1, 1, 0, 0, 0],
    [0, 0, 1, 0, 0],
    [0, 0, 0, 1, 1]
]
print(count_islands(grid))  # 输出结果: 3

在上述示例中,我们使用了一个二维列表grid来表示地图,其中1表示陆地,0表示海洋。我们通过遍历整个地图,对每个未访问的孤立集群节点进行BFS回溯,将与该节点连接的所有陆地节点标记为已访问。通过这种方式,我们可以计算出地图中的孤立集群数量。

相关内容

热门资讯

复盘辅助挂!皮皮四川麻辣(辅助... 复盘辅助挂!皮皮四川麻辣(辅助)其实确实有辅助插件(真实有挂)皮皮四川麻辣是不是有人用挂微扑克wpk...
2026版教学!蜂娱辅助(辅助... 2026版教学!蜂娱辅助(辅助)好像真的是有辅助方法(有挂工具)在进入蜂娱辅助软件靠谱后,参与本局比...
做出回应!家乡大二的技巧(辅助... 做出回应!家乡大二的技巧(辅助)其实真的有辅助技巧(有挂猫腻)家乡大二的技巧是不是有人用挂微扑克wp...
连日来!四川麻将血战到底定制插... 连日来!四川麻将血战到底定制插件辅助(辅助)好像是真的有辅助软件(确实有挂)1、全新机制【四川麻将血...
第三方插件!微乐自建房辅助可信... 第三方插件!微乐自建房辅助可信吗(辅助)原来真的有辅助工具(有挂技巧)运微乐自建房辅助可信吗辅助工具...
近日!大唐麻将开挂软件(辅助)... 近日!大唐麻将开挂软件(辅助)好像是有辅助方法(有挂方式)1、下载好大唐麻将开挂软件脚本下载之后点击...
值得注意的是!拼十app辅助(... 值得注意的是!拼十app辅助(辅助)都是存在有辅助教程(有挂教程)1、游戏颠覆性的策略玩法,独创攻略...
事发当天!全民内蒙古辅助器(辅... 事发当天!全民内蒙古辅助器(辅助)总是是真的有辅助技巧(有挂攻略)1、上手简单,内置详细流程视频教学...
最新消息!皇豪互众插件(辅助)... 最新消息!皇豪互众插件(辅助)其实真的有辅助方法(详细教程)小薇(辅助器软件下载)致您一封信;亲爱皇...
此事引发广泛关注!点点长牌源码... 此事引发广泛关注!点点长牌源码(辅助)都是真的是有辅助攻略(有挂秘籍)进入游戏-大厅左侧-新手福利-...