树与图的深度优先遍历

数和图的存储方式与遍历

数和图的存储方式:

一般有两种
树是一种特殊的图(即无环联通图)。所以下面只讲图。

图的话分为两种:①有向图(边是有方向的:a➡️b)和
②无向图(边是无方向的:a——b)。这里无向图可以定义:a➡️b和b⬅️a来表达无向图
无向图可以看成特殊的有向图,所以接下来分析有向图

有向图,存储有两大类{
    ①:邻接矩阵,开个二维数组g[a][b]表示a➡️b,如果有权重,则g[a][b]表示权值。
邻接矩阵不能保存重复的边,若有的重边话只能保留一条,适合于最短路,空间复杂度为n^2。
    ②:邻接表——单链表。每个点上都有一个单链表,若有n个点就开n个单链表,每一个节点上开一个表。
每一个点存一个路径,就是存这个点能走到哪一个点。这里的路径无关顺序,也就是说除了根节点其余的都是子节点。插入方法和链表的插入方法一致
}

数和图的遍历:

有两种:①深度优先遍历,②宽度优先遍历
①:选取一个起点,从这个起点开始,向下DFS
②:BFS

题目:846. 树的重心 - AcWing题库

 思路:

 本题是无向边,所以要建两条边互相指向。
"重心定义:重心是指树中的一个结点,如果将这个点删除后,剩余各个连通块中点数的最大值最小,那么这个节点被称为树的重心。"
题目这句话的意思是:将某一个点删除之后,然后将剩下的每一块区域中含有多少
节点给统计出来,取一个最大值。循环操作,记录每一个节点删除后,所剩下区域的最大值都给记录出来然后在所有最大值里面取一个最小值,这个最小值就是题目所要求解。

图示:

代码: 

~~暴力无从下手~~

#include<iostream>
#include<algorithm>
#include<cstring>using namespace std;int n;
const int N=1e5+10,M=N*2;
//h[u]即每一个点都可以作为头节点,向下遍历
int h[N],e[M],ne[M],idx;
//每个点只搜索一次
bool st[N];
//所有最大值中的最小值
int ans=N;void add(int a,int b)
{e[idx]=b,ne[idx]=h[a],h[a]=idx,idx++;
}
//从u开始向下遍历。返回以u为根节点的子树中点的数量
int dfs(int u)
{//标记一下,当前这个点已经被搜过了st[u]=true;//sum为以此节点作为根节点区域的所有节点的数量,res表示删去这个节点后 所有连通块中的最大值int sum=1,res=0;//遍历一下u的所有可能移动的边,i每一次向下移动一个即等于当前点的下一个指向
//是从头开始遍历的,所以不需要恢复操作for(int i=h[u]; i!=-1 ;i=ne[i]){//当前这个点对应图中节点的编号是多少int j=e[i];//这个点只使用一次,不需要回溯也就不需要恢复st[j]的bool值if(!st[j]) {int s=dfs(j);//取这个区域和上个区域连通块节点数量的最大值res=max(s,res);//计算以此节点作为根节点区域的所有节点的数量sum+=s;}}//不是以这个点作为根节点之外的区域的所有节点数量(n-sum),与根节点区域里的节点数量(res)取最大值res=max(res,n-sum);//和所有的最大值取一个最小值ans=min(res,ans);//返回一块区域的节点数量return sum;
}int main()
{//每个点都可以作为根节点,所以初始化为-1memset(h,-1,sizeof h);cin >> n;for(int i=0;i<n;i++){int a,b;cin >> a >> b;//因为是无向边,所以可以认为是互相指向add(a,b),add(b,a);}
//从哪一个节点深搜都是可以的,因为ans总能更新成最大值里的最小值dfs(1);cout << ans;return 0;
}

 tips:

这里的dfs中不需要恢复st[ j ]的原因是这里只需要遍历一遍所有的节点,然后求出以u作为根节点的数量即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/844783.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HNU-计算机体系结构-实验2-Tomasulo算法

计算机体系结构 实验2 计科210X 甘晴void 202108010XXX 1 实验目的 熟悉Tomasulo模拟器同时加深对Tomasulo算法的理解&#xff0c;从而理解指令级并行的一种方式-动态指令调度。 掌握Tomasulo算法在指令流出、执行、写结果各阶段对浮点操作指令以及load和store指令进行什么…

网络融合的力量:企业如何通过“一网多用”提升业务效率

随着企业业务的不断扩展&#xff0c;网络需求变得日益复杂。需要的是一种能够统一承载办公、生产、销售和运营等多业务需求的网络架构。这种“一网多用”的架构&#xff0c;不仅简化了网络部署和管理&#xff0c;还提升了效率并降低了成本。 “一网多用”架构的实际应用&#x…

Guns框架:基于主流技术Spring Boot2 + Vue3 + Antd Vue的现代Java应用开发新纪元

Guns框架&#xff1a;基于主流技术Spring Boot2 Vue3 Antd Vue的现代Java应用开发新纪元 摘要&#xff1a;随着信息技术的飞速发展&#xff0c;软件开发框架在提升开发效率、降低成本方面扮演着至关重要的角色。Guns框架&#xff0c;作为一个现代化的Java应用开发框架&#x…

微信图片识别文字怎么弄?介绍三个识别方法

微信图片识别文字怎么弄&#xff1f;在信息爆炸的时代&#xff0c;我们每天都会接触到大量的图片信息&#xff0c;其中包含的文字内容往往是我们获取信息的重要途径。然而&#xff0c;手动输入图片中的文字既费时又费力&#xff0c;这时&#xff0c;一款能够准确识别微信图片中…

学习笔记——动态路由协议——OSPF(OSPF基本术语)

OSPF基本术语 1、链路状态(LS)与链路状态通告(LSA) 链路(LINK)&#xff1a;路由器上的一个接口。 状态(State)&#xff1a;描述接口以及其与邻居路由器之间的关系。 (1)链路状态(LS) OSPF是一种链路状态协议&#xff0c;所谓的链路状态&#xff0c;其实就是路由器的接口状态…

QGIS开发笔记(三):Windows安装版二次开发环境搭建(下):将QGis融入QtDemo,添加QGis并加载tif遥感图的Demo

若该文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/139136356 长沙红胖子Qt&#xff08;长沙创微智科&#xff09;博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV…

29-ESP32-S3-WIFI篇-00 STA模式扫描全部 AP

ESP32-S3 WIFI_Driver 引言 ESP32-S3是一款集成了Wi-Fi和蓝牙功能的芯片。关于WIFI的部分&#xff0c;其实内容比我想象的要多得多。所以通常来说&#xff0c;如果你想要编写自己的Wi-Fi应用程序&#xff0c;最快捷的方法就是先找一个类似的示例应用&#xff0c;然后将它的相…

实战项目:飞机坦克大战 —— 面向对象编程之旅

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、项目概览与背景介绍 二、面向对象编程基本概念解析 1. 类与对象 2. 构造函数与属性封…

Java对象的揭秘

前言 作为一个 Java 程序员&#xff0c;我们在开发中最多的操作要属创建对象了。那么你了解对象多少&#xff1f;它是如何创建&#xff1f;如何存储布局以及如何使用的&#xff1f;本文将对 Java 对象进行揭秘&#xff0c;以及讲解如何使用 JOL 查看对象内存使用情况。 本文是基…

车载客流统计设备:双目3D还原智能统计算法的应用与优势

随着城市交通的日益繁忙和公共交通系统的不断完善&#xff0c;对公交车等交通工具的客流统计和分析变得越来越重要。传统的客流统计方法往往存在效率低下、精度不足等问题&#xff0c;难以满足现代城市交通管理的需求。而基于双目3D还原智能统计算法的车载客流统计设备&#xf…

智能家居ZigBee网关选型定制指南:主控,操作系统,天线设计,助力IoT开发者

随着科技的发展和人们生活水平的提高&#xff0c;智能家居以其便捷、舒适、安全等特点&#xff0c;逐渐走进千家万户&#xff0c;成为家装消费品换新升级的重要方向。在智能家居系统中&#xff0c;网关扮演着中枢控制器的角色&#xff0c;负责将各种设备连接到互联网上&#xf…

分布式数据库OceanBase的安装

OceanBase是阿里自研的分布式数据库&#xff0c;单集群规模超过 1500 节点&#xff0c;具有云原生、强一致性、高度兼容 Oracle/MySQL 等特性。今天讲一讲OceanBase的安装&#xff0c;官网上面有详细的介绍&#xff0c;这里主要是针对容器部署详细介绍安装步骤一些过程中遇到的…

【单片机毕设选题】-智能语音控制风扇

一. 系统功能 此设计采用STM32和SU-03T离线语音模块来控制风扇, 主要功能如下: 1. 通过DHT11温湿度模块来采集环境温湿度。 2. 通过SU-03T语音模块来控制风扇启停加减速等。 3. 通过OLED显示系统状态。 4. 可以通过按键控制风扇启停加减速等。 5. 通过蓝牙模块监视系统状…

Tomcat启动过程

ClassLoader初始化 发生在org.apache.catalina.startup.Bootstrap#init() Catalina初始化 1、加载Digester工具 发生在org.apache.catalina.startup.Catalina#load() 2、容器启动&#xff0c;启用StandardContext维持Socket连接 Digester工具初始化 发生在org.apache.catali…

攀爬二叉树,发现新的美

二叉树 什么是二叉树? 二叉树的基础概念? 性质? 问题? 文章目录 二叉树一、二叉树的概念(一)认识二叉树(二)二叉树的性质 二、遍历二叉树1.前序遍历2.中序遍历3.后序遍历4.层序遍历 三丶创建二叉树总结 一、二叉树的概念 (一)认识二叉树 二叉树是一种非线性的数据结构,…

HAL库+LWIP+LAN8720+热插拔

定时任务中&#xff0c;查询LAN8720的状态寄存器 PHY_BSR 0x01&#xff0c;成功读取后&#xff0c;检查16位数据的BIT2&#xff0c;即可获取网线连接状态 uint32_t phyreg 0;if(HAL_ETH_ReadPHYRegister(&g_eth_handler, PHY_BSR, &phyreg) HAL_OK){if(((phyreg >…

Java内存模型(JMM)

1.背景 JMM(Java Memory Model)的提出&#xff0c;主要基于以下的几种原因&#xff1a; 不同操作系统平台的内存模型不同&#xff0c;而Java又想做到Write Once Run Everywhere(即跨平台)&#xff0c;那么必须要自己提供一套内存模型以屏蔽不同操作系统在内存模型方面的差异。…

断开自定义模块与自定义库的链接

断开自定义模块与自定义库的链接 1、断开模块与库的链接 1、断开模块与库的链接 如果摸个库文件添加到模型中&#xff0c;无法“Disable Link”时&#xff0c;可以使用save_system命令进行断开到模型中用户定义的库模块的链接&#xff1b; 参考链接&#xff1a; 传送门 save…

docker占用磁盘空间大小排查

首先进入到 /var/lib/docker/overlay2 目录下,查看谁占用的较多 cd /var/lib/docker/overlay2/du -s ./* | sort -rn | more再通过目录名查找容器名 docker ps -q | xargs docker inspect --format {{.State.Pid}}, {{.Id}}, {{.Name}}, {{.GraphDriver.Data.WorkDir}} | gre…

《C语言深度解剖》(16):C语言的文件读写操作

&#x1f921;博客主页&#xff1a;醉竺 &#x1f970;本文专栏&#xff1a;《C语言深度解剖》 &#x1f63b;欢迎关注&#xff1a;感谢大家的点赞评论关注&#xff0c;祝您学有所成&#xff01; ✨✨&#x1f49c;&#x1f49b;想要学习更多C语言深度解剖点击专栏链接查看&…