Day50-图论

99. 岛屿数量

99. 计数孤岛

深搜
python 复制代码
DIR = [[0,1],[1,0],[0,-1],[-1,0]]  

def dfs1(graph,visited,x,y):
    for i in range(4):
        nextx = x+DIR[i][0]
        nexty = y+DIR[i][1]
        if nextx<0 or nexty<0 or nextx>=len(graph) or nexty>=len(graph[0]):
            continue
        if not visited[nextx][nexty] and graph[nextx][nexty]:
            visited[nextx][nexty] = 1
            dfs1(graph,visited,nextx,nexty)


def main():
    n,m = map(int,input().split())
    graph = []
    for i in range(n):
        graph.append(list(map(int,input().split())))
    visited = [[0]*m for _ in range(n)]
    res = 0
    for i in range(n):
        for j in range(m):
            if graph[i][j] and not visited[i][j]:
                # 发现新大陆
                res +=1
                visited[i][j] = 1
                # 查看周围的领土
                dfs1(graph,visited,i,j)
    print(res)

if __name__ == '__main__':
    main()
python 复制代码
DIR = [[0,1],[1,0],[0,-1],[-1,0]]  

def dfs2(graph,visited,x,y):
    if visited[x][y] or not graph[x][y]:  
        # 海洋或者已经处理过的陆地,不重复访问
        return
    visited[x][y] = 1
    for i in range(4):
        nextx = x+DIR[i][0]
        nexty = y+DIR[i][1]
        if nextx<0 or nexty<0 or nextx>=len(graph) or nexty>=len(graph[0]):
            continue
        dfs2(graph,visited,nextx,nexty)


def main():
    n,m = map(int,input().split())
    graph = []
    for i in range(n):
        graph.append(list(map(int,input().split())))
    visited = [[0]*m for _ in range(n)]
    res = 0
    for i in range(n):
        for j in range(m):
            if graph[i][j] and not visited[i][j]:
                # 发现新大陆
                res +=1
                # 查看周围的领土
                dfs2(graph,visited,i,j)
    print(res)

if __name__ == '__main__':
    main()
广搜
python 复制代码
DIR = [[0,1],[1,0],[0,-1],[-1,0]]  

def bfs(graph,visited,x,y):
    # 坑:入队列就要变成访问过;如果取出的时候才标记访问过,会有大量重复节点被标记
    queue = []
    queue.append([x,y])
    visited[x][y] = 1
    while queue:
        curx,cury = queue.pop(0)
        for i in range(4):
            nextx = curx+DIR[i][0]
            nexty = cury+DIR[i][1]
            if nextx<0 or nexty<0 or nextx>=len(graph) or nexty>=len(graph[0]):
                continue
            if not visited[nextx][nexty] and graph[nextx][nexty]:
                queue.append([nextx,nexty])
                visited[nextx][nexty] = 1

def main():
    n,m = map(int,input().split())
    graph = []
    for i in range(n):
        graph.append(list(map(int,input().split())))
    visited = [[0]*m for _ in range(n)]
    res = 0
    for i in range(n):
        for j in range(m):
            if graph[i][j] and not visited[i][j]:
                # 发现新大陆
                res +=1
                # 查看周围的领土
                bfs(graph,visited,i,j)
    print(res)

if __name__ == '__main__':
    main()

100. 岛屿的最大面积

100. 最大岛屿的面积

深搜
python 复制代码
DIR = [[0,1],[1,0],[0,-1],[-1,0]] 
count = 0  # 全局,因为dfs可能拿不到返回值【第一种写法】

def dfs1(graph,visited,x,y):
    global count
    for i in range(4):
        nextx = x+DIR[i][0]
        nexty = y+DIR[i][1]
        if nextx<0 or nexty<0 or nextx>=len(graph) or nexty>=len(graph[0]):
            continue
        if not visited[nextx][nexty] and graph[nextx][nexty]:
            visited[nextx][nexty] = 1
            count +=1
            dfs1(graph,visited,nextx,nexty)


def main():
    n,m = map(int,input().split())
    graph = []
    for i in range(n):
        graph.append(list(map(int,input().split())))
    visited = [[0]*m for _ in range(n)]
    res = 0
    global count
    for i in range(n):
        for j in range(m):
            if graph[i][j] and not visited[i][j]:
                # 发现新大陆,陆地面积置为1
                count = 1
                visited[i][j] = 1
                # 查看周围的领土
                dfs1(graph,visited,i,j)
                # 全局的count在遍历中得到了更新
                res = max(res,count)
    print(res)

if __name__ == '__main__':
    main()
python 复制代码
DIR = [[0,1],[1,0],[0,-1],[-1,0]] 
count = 0  # 全局,因为dfs可能拿不到返回值【第一种写法】

def dfs2(graph,visited,x,y):
    global count
    if not graph[x][y] or visited[x][y]:
        return
    visited[x][y] = 1
    count +=1
    for i in range(4):
        nextx = x+DIR[i][0]
        nexty = y+DIR[i][1]
        if nextx<0 or nexty<0 or nextx>=len(graph) or nexty>=len(graph[0]):
            continue
        dfs2(graph,visited,nextx,nexty)

def main():
    n,m = map(int,input().split())
    graph = []
    for i in range(n):
        graph.append(list(map(int,input().split())))
    visited = [[0]*m for _ in range(n)]
    res = 0
    global count
    for i in range(n):
        for j in range(m):
            if graph[i][j] and not visited[i][j]:
                # 发现新大陆,陆地面积置为1
                count = 0
                # 查看周围的领土
                dfs2(graph,visited,i,j)
                # 全局的count在遍历中得到了更新
                res = max(res,count)
    print(res)

if __name__ == '__main__':
    main()
广搜
python 复制代码
DIR = [[0,1],[1,0],[0,-1],[-1,0]] 
count = 0  # 全局,因为dfs可能拿不到返回值【第一种写法】


def bfs(graph,visited,x,y):
    queue = []
    queue.append([x,y])
    visited[x][y] = 1
    global count
    count = 1
    while queue:
        curx,cury = queue.pop(0)
        for i in range(4):
            nextx = curx+DIR[i][0]
            nexty = cury+DIR[i][1]
            if nextx<0 or nexty<0 or nextx>=len(graph) or nexty>=len(graph[0]):
                continue
            if not visited[nextx][nexty] and graph[nextx][nexty]:
                queue.append([nextx,nexty])
                visited[nextx][nexty] = 1
                count +=1

def main():
    n,m = map(int,input().split())
    graph = []
    for i in range(n):
        graph.append(list(map(int,input().split())))
    visited = [[0]*m for _ in range(n)]
    res = 0
    global count
    for i in range(n):
        for j in range(m):
            if graph[i][j] and not visited[i][j]:
                # 发现新大陆,陆地面积置为1
                visited[i][j] = 1
                # 查看周围的领土
                bfs(graph,visited,i,j)
                # 全局的count在遍历中得到了更新
                res = max(res,count)
    print(res)

if __name__ == '__main__':
    main()
相关推荐
无风听海2 小时前
CBOW输入层向量形式深入解析
人工智能·算法·机器学习
好好学操作系统2 小时前
notion+excel自动创建表格| 了解了notion api
数据库·python·oracle·excel·notion
Shirley~~2 小时前
leetcode二分法
数据结构·算法·leetcode
一晌小贪欢2 小时前
用 PyQt5 做一个「批量目录重命名」工具,并打包成带图标的 EXE
开发语言·驱动开发·python·python基础·python小白
LDG_AGI2 小时前
【机器学习】深度学习推荐系统(二十九):X 推荐算法多样性打散机制详解
人工智能·深度学习·算法·机器学习·推荐算法
sunfove2 小时前
Python制作小游戏:用线性代数思想构建 2048 游戏引擎
python·线性代数·游戏引擎
小二·2 小时前
Python Web 开发进阶实战:时空数据引擎 —— 在 Flask + Vue 中构建实时地理围栏与轨迹分析系统
前端·python·flask
Uncertainty!!2 小时前
pycharm本地Failed to open X display(exiting)
ide·python·pycharm
小二·2 小时前
Python Web 开发进阶实战:可验证网络 —— 在 Flask + Vue 中实现去中心化身份(DID)与零知识证明(ZKP)认证
前端·网络·python