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()
相关推荐
2301_803934613 小时前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
WL_Aurora3 小时前
Python爬虫实战(六):新发地蔬菜价格数据采集.
爬虫·python
盲敲代码的阿豪3 小时前
Python 入门基础教程(爬虫前置版)
开发语言·爬虫·python
weixin199701080164 小时前
[特殊字符] 智能数据采集:数字化转型的“数据石油勘探队”(附Python实战源码)
开发语言·python
淘矿人4 小时前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
Cosolar4 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
小江的记录本4 小时前
【Java基础】泛型:泛型擦除、通配符、上下界限定(附《思维导图》+《面试高频考点清单》)
java·数据结构·后端·mysql·spring·面试·职场和发展
次元工程师!4 小时前
LangFlow开发(三)—Bundles组件架构设计(3W+字详细讲解)
java·前端·python·低代码·langflow
t_hj5 小时前
大模型微调
人工智能·python·深度学习