java数据结构与算法刷题-----LeetCode547. 省份数量

2024-04-03 10:52

本文主要是介绍java数据结构与算法刷题-----LeetCode547. 省份数量,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846

文章目录

    • 深度优先遍历
    • 广度优先遍历

在这里插入图片描述

本题考察图的连通分量个数。也就是所有直接或间接通过边相连的顶点构成一个连通分量,一个无向图有1到多个连通分量组成

深度优先遍历

解题思路:时间复杂度O( n 2 n^2 n2),需要遍历每一条边,空间复杂度O( n n n),需要一个数组标识n个顶点是否访问过
  1. 这是一个由领接矩阵表示的图,特点是用一个二维数组arr[i][j]表示顶点之间的关系。i表示顶点,j表示i这个顶点与谁有边。例如arr[0][3],就是是说0这个顶点和3这个顶点有一条边,他俩是连通的
  2. 我们依次访问每个顶点,并遍历其边的信息,如果有边,就遍历这条边相连的顶点B,然后再次遍历B的边,依次类推
代码

在这里插入图片描述

class Solution {public int findCircleNum(int[][] isConnected) {int count=0;//最终答案int L = isConnected.length;//顶点个数boolean[] visit=new boolean[L];//顶点是否访问for(int i=0;i<L;++i)//遍历每个顶点{if(!visit[i])//如果没有访问过{dfs(isConnected,i,visit);//访问其连通分量count+=1;//连通分量数量+1}}return count;//连通分量的个数}public void dfs(int[][] isConnected,int i,boolean[] visit)//深度遍历其连通分量{visit[i]=true;//设置当前顶点为访问过的状态for(int k=0;k<isConnected.length;++k)//遍历其边{    //如果当前边相连顶点没有访问过,并且当前边存在的话,就遍历这个顶点if(visit[k]==false && isConnected[i][k]==1)dfs(isConnected,k,visit);}}}

广度优先遍历

解题思路:时间复杂度O( n 2 n^2 n2),空间复杂度O( n n n)

将深度优先遍历的代码换成广度优先即可

代码

在这里插入图片描述

class Solution {public int findCircleNum(int[][] isConnected) {int cities = isConnected.length;//顶点个数boolean[] visited = new boolean[cities];//是否访问int provinces = 0;//连通分量个数Queue<Integer> queue = new LinkedList<Integer>();//队列,用于广度优先遍历for (int i = 0; i < cities; i++) {if (!visited[i]) {//如果当前顶点没有访问queue.offer(i);//对其广度优先遍历while (!queue.isEmpty()) {int j = queue.poll();//出队列visited[j] = true;//标为访问过for (int k = 0; k < cities; k++) {//遍历其边if (isConnected[j][k] == 1 && !visited[k]) {//如果边存在且顶点没有访问过queue.offer(k);//就入队列,下次继续广度优先遍历}}}provinces++;//遍历完成一个连通分量}}return provinces;}
}

这篇关于java数据结构与算法刷题-----LeetCode547. 省份数量的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security+JWT如何实现前后端分离权限控制

《SpringSecurity+JWT如何实现前后端分离权限控制》本篇将手把手教你用SpringSecurity+JWT搭建一套完整的登录认证与权限控制体系,具有很好的参考价值,希望对大家... 目录Spring Security+JWT实现前后端分离权限控制实战一、为什么要用 JWT?二、JWT 基本结构

java解析jwt中的payload的用法

《java解析jwt中的payload的用法》:本文主要介绍java解析jwt中的payload的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解析jwt中的payload1. 使用 jjwt 库步骤 1:添加依赖步骤 2:解析 JWT2. 使用 N

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

Java实现优雅日期处理的方案详解

《Java实现优雅日期处理的方案详解》在我们的日常工作中,需要经常处理各种格式,各种类似的的日期或者时间,下面我们就来看看如何使用java处理这样的日期问题吧,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言一、日期的坑1.1 日期格式化陷阱1.2 时区转换二、优雅方案的进阶之路2.1 线程安全重构2

Java中的JSONObject详解

《Java中的JSONObject详解》:本文主要介绍Java中的JSONObject详解,需要的朋友可以参考下... Java中的jsONObject详解一、引言在Java开发中,处理JSON数据是一种常见的需求。JSONObject是处理JSON对象的一个非常有用的类,它提供了一系列的API来操作J

SpringBoot多数据源配置完整指南

《SpringBoot多数据源配置完整指南》在复杂的企业应用中,经常需要连接多个数据库,SpringBoot提供了灵活的多数据源配置方式,以下是详细的实现方案,需要的朋友可以参考下... 目录一、基础多数据源配置1. 添加依赖2. 配置多个数据源3. 配置数据源Bean二、JPA多数据源配置1. 配置主数据

将Java程序打包成EXE文件的实现方式

《将Java程序打包成EXE文件的实现方式》:本文主要介绍将Java程序打包成EXE文件的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录如何将Java程序编程打包成EXE文件1.准备Java程序2.生成JAR包3.选择并安装打包工具4.配置Launch4

SpringBoot内嵌Tomcat临时目录问题及解决

《SpringBoot内嵌Tomcat临时目录问题及解决》:本文主要介绍SpringBoot内嵌Tomcat临时目录问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录SprinjavascriptgBoot内嵌Tomcat临时目录问题1.背景2.方案3.代码中配置t

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

Java程序进程起来了但是不打印日志的原因分析

《Java程序进程起来了但是不打印日志的原因分析》:本文主要介绍Java程序进程起来了但是不打印日志的原因分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java程序进程起来了但是不打印日志的原因1、日志配置问题2、日志文件权限问题3、日志文件路径问题4、程序