LeetCode in Python 200. Number of islands (岛屿数量)

2024-04-20 11:12

本文主要是介绍LeetCode in Python 200. Number of islands (岛屿数量),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

岛屿数量既可以用深度优先搜索也可以用广度优先搜索解决,本文给出两种方法的代码实现。

示例:

图1 岛屿数量输入输出示意图 

 方法一:广度优先搜索(bfs)

代码:

class Solution:def numIslands(self, grid):if not grid:return 0rows, cols = len(grid), len(grid[0])visit = set()islands = 0def bfs(r, c):que = deque()que.append((r, c))visit.add((r, c))while que:row, col = que.popleft()directions = [[1, 0], [-1, 0], [0, 1], [0, -1]]for dr, dc in directions:r, c = row + dr, col + dcif r in range(rows) and c in range(cols) and grid[r][c] == "1" and (r, c) not in visit:que.append((r, c))visit.add((r, c))for r in range(rows):for c in range(cols):if grid[r][c] == "1" and (r, c) not in visit:bfs(r, c)islands += 1return islands

解释:

1)visit记录所有已经遍历的位置集合,如果该位置值为1且还未遍历到,则对该位置进行bfs,并增加一块岛屿数量。bfs中设置了一个队列que用于记录需要遍历的节点,directions为每个节点需要遍历的四个方向,分别对应右、左、上、下。对每个位置进行判断,如果该位置未越界、值为1且未被遍历到,则将该结点加入即将需要遍历的节点队列中,并将其放入已经遍历的节点集合中。

方法二:深度优先搜索(dfs)

代码:

class Solution:def numIslands(self, grid):if not grid:return 0    rows, cols = len(grid), len(grid[0])islands = 0def dfs(r, c):if r not in range(rows) or c not in range(cols) or grid[r][c] == "0":returngrid[r][c] = "0"dfs(r + 1, c)dfs(r - 1, c)dfs(r, c + 1)dfs(r, c - 1)for r in range(rows):for c in range(cols):if grid[r][c] == "1":dfs(r, c)islands += 1return islands

解释:

1)深度优先搜索相较于广度优先搜索,选择将遍历过的节点的值置为“0”以免重复遍历,同时dfs采用递归方法来实现对四个位置上节点的判断。

这篇关于LeetCode in Python 200. Number of islands (岛屿数量)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/920105

相关文章

使用Python实现实时金价监控并自动提醒功能

《使用Python实现实时金价监控并自动提醒功能》在日常投资中,很多朋友喜欢在一些平台买点黄金,低买高卖赚点小差价,但黄金价格实时波动频繁,总是盯着手机太累了,于是我用Python写了一个实时金价监控... 目录工具能干啥?手把手教你用1、先装好这些"食材"2、代码实现讲解1. 用户输入参数2. 设置无头浏

一文教你如何解决Python开发总是import出错的问题

《一文教你如何解决Python开发总是import出错的问题》经常朋友碰到Python开发的过程中import包报错的问题,所以本文将和大家介绍一下可编辑安装(EditableInstall)模式,可... 目录摘要1. 可编辑安装(Editable Install)模式到底在解决什么问题?2. 原理3.

Python+wxPython构建图像编辑器

《Python+wxPython构建图像编辑器》图像编辑应用是学习GUI编程和图像处理的绝佳项目,本教程中,我们将使用wxPython,一个跨平台的PythonGUI工具包,构建一个简单的... 目录引言环境设置创建主窗口加载和显示图像实现绘制工具矩形绘制箭头绘制文字绘制临时绘制处理缩放和旋转缩放旋转保存编

Python 异步编程 asyncio简介及基本用法

《Python异步编程asyncio简介及基本用法》asyncio是Python的一个库,用于编写并发代码,使用协程、任务和Futures来处理I/O密集型和高延迟操作,本文给大家介绍Python... 目录1、asyncio是什么IO密集型任务特征2、怎么用1、基本用法2、关键字 async1、async

Python实现剪贴板历史管理器

《Python实现剪贴板历史管理器》在日常工作和编程中,剪贴板是我们使用最频繁的功能之一,本文将介绍如何使用Python和PyQt5开发一个功能强大的剪贴板历史管理器,感兴趣的可以了解下... 目录一、概述:为什么需要剪贴板历史管理二、功能特性全解析2.1 核心功能2.2 增强功能三、效果展示3.1 主界面

Python与Java交互出现乱码的问题解决

《Python与Java交互出现乱码的问题解决》在现代软件开发中,跨语言系统的集成已经成为日常工作的一部分,特别是当Python和Java之间进行交互时,编码问题往往会成为导致数据传输错误、乱码以及难... 目录背景:为什么会出现乱码问题产生的场景解决方案:确保统一的UTF-8编码完整代码示例总结在现代软件

Python+Tkinter实现Windows Hosts文件编辑管理工具

《Python+Tkinter实现WindowsHosts文件编辑管理工具》在日常开发和网络调试或科学上网场景中,Hosts文件修改是每个开发者都绕不开的必修课,本文将完整解析一个基于Python... 目录一、前言:为什么我们需要专业的Hosts管理工具二、工具核心功能全景图2.1 基础功能模块2.2 进

Python多重继承慎用的地方

《Python多重继承慎用的地方》多重继承也可能导致一些问题,本文主要介绍了Python多重继承慎用的地方,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录前言多重继承要慎用Mixin模式最后前言在python中,多重继承是一种强大的功能,它允许一个

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj

Python中edge-tts实现便捷语音合成

《Python中edge-tts实现便捷语音合成》edge-tts是一个功能强大的Python库,支持多种语言和声音选项,本文主要介绍了Python中edge-tts实现便捷语音合成,具有一定的参考价... 目录安装与环境设置文本转语音查找音色更改语音参数生成音频与字幕总结edge-tts 是一个功能强大的