当前位置: 首页 > news >正文

搜索与图论 树的广度优先遍历 图中点的层次

适用性

当边的权值相等时,使用广度优先遍历,往往是求图(树)的最短路径最优方法

抽象理解

伪代码

建立队列
添加第一个起始点到队列,标记其不可访问
while(队列不为空)//开始循环{获取队列中的队首元素,获取到后,让其出列,也就是删除for(遍历对首元素上下左右四个方向){将对首元素,可以访问的邻接点加入到队列将加入的点标记为不可访问记录加入的点的步数}}

重边,自环

先了解图中,重边和自环的概念

a节点有同方向指向b节点的两根边,就是重边

c节点有指向自己的边,就是自环

图中点的层次

给给定一个 n 个点 m 条边的有向图,图中可能存在重边和自环。

所有边的长度都是 1,点的编号为 1∼n

请你求出 1 号点到 n 号点的最短距离,如果从 1 号点无法走到 n 号点,输出 −1。

输入格式

第一行包含两个整数 nm

接下来 m 行,每行包含两个整数 ab,表示存在一条从 a 走到 b 的长度为 1 的边。

输出格式

输出一个整数,表示 1 号点到 ( n ) 号点的最短距离。

数据范围

1≤n,m≤105

输入样例:

4 5
1 2
1 2
2 3
2 3
3 4
1 3
1 4

输出样例:

1

解题

#include<iostream>
#include<queue>
#include<cstring>
using namespace std;
const int N = 100010; 
int n,m,idx;
int e[N],ne[N],f[N];//f[i]记录从1到i需要多少步,默认-1,视为未到达
int h[N];//h[i]记录i节点所有可以走到的所有节点(单链表头结点)
int add(int a,int b){//a可以走到b,则在a为头的单链表中,添加be[idx] = b;ne[idx] = h[a];h[a] = idx;idx++;
}
int bfs(){queue<int> q;//创建队列f[1]=0;//初始点1走到点1需要0步q.push(1);//将1加入队列while(q.size()){//队列不为空,那么从1出发可以走到的所有点还没走完int t = q.front();//取出队列中头节点q.pop();//遍历t所有可以走到的相邻节点,也就是t为头的单链表for(int i=h[t];i!=-1;i=ne[i]){int j=e[i];//j是t的相邻节点if(f[j]==-1){//该相邻节点还未走过//将j加入队列,后续t的所有相邻节点都遍历完,t会变成jq.push(j);//后续遍历j的所有相邻节点,达到从1点出发,遍历全图效果f[j]=f[t]+1;//记录步数			}}}return f[n];
}
int main(){cin>>n>>m;int a,b;memset(f,-1,sizeof f);//未达到时都是-1步memset(h,-1,sizeof h);//初始化各节点邻接表,邻接表用单链表头存储,初始指向-1for(int i=0;i<m;i++){cin>>a>>b;add(a,b);    }cout<<bfs();return 0;
}

相关文章:

搜索与图论 树的广度优先遍历 图中点的层次

适用性 当边的权值相等时&#xff0c;使用广度优先遍历&#xff0c;往往是求图&#xff08;树&#xff09;的最短路径最优方法 抽象理解 伪代码 建立队列 添加第一个起始点到队列&#xff0c;标记其不可访问 while(队列不为空)//开始循环{获取队列中的队首元素&#xff0c;获…...

DHCP之报文格式

字段说明&#xff1a; op (op code): 表示报文的类型&#xff0c;取值为 1 或 2&#xff0c;含义如下 1:客户端请求报 2:服务器响应报文 Secs (seconds):由客户端填充&#xff0c;表示从客户端开始获得 IP 地址或 IP 地址续借后所使用了的秒数&#xff0c;缺省值为 3600s。 F…...

Docker安装、配置Redis

1.如果没有docker-compose.yml文件的话&#xff0c;先创建docker-compose.yml 配置文件一般长这个样子 version: 3services:redis:image: redis:latestcontainer_name: redisports:- "6379:6379"command: redis-server --requirepass "123456"restart: a…...

空中无人机等动态目标识别2025.4.4

* 一.无人机动态数据概述* 1.1 空中动态数据定义 在无人机动态数据的范畴中&#xff0c; 空中动态数据 是一个核心概念。它主要包括无人机在飞行过程中产生的各种实时信息&#xff0c;如 位置、速度、高度、姿态 等[1]。这些数据通过传感器系统采集&#xff0c;并以特定格式存…...

【AI论文】通过R1-Zero类似训练改进视觉空间推理

摘要&#xff1a;人们越来越关注提升多模态大型语言模型&#xff08;MLLMs&#xff09;的推理能力。作为在物理领域中运作的人工智能代理的基石&#xff0c;基于视频的视觉空间智能&#xff08;VSI&#xff09;成为MLLMs最为关键的推理能力之一。本研究首次深入探讨了通过R1-Ze…...

游戏引擎学习第203天

回顾当前情况 在这里我将直播完成整个游戏的制作。我们现在面临一些技术上的困难&#xff0c;确实如此。我的笔记本电脑的电源接口坏了&#xff0c;所以我不得不准备了这台备用笔记本&#xff0c;希望它能够正常工作。我所以希望一切都还好&#xff0c;尽管我不完全确定是否一…...

从菜鸟到高手的提示词优化指南‌

如何用“说话的艺术”榨干AI潜力&#xff1f; ——从菜鸟到高手的提示词优化指南‌ 一、什么是好的提示词&#xff1f; 核心公式‌&#xff1a;精准提问 明确需求 限定条件 示范案例 好比让AI帮你买咖啡—— ❌ 差提示&#xff1a;“帮我买杯咖啡”&#xff08;AI可能随便…...

应对高并发的根本挑战:思维转变【大模型总结】

以下是对这篇技术总结的详细解析&#xff0c;以分步说明的形式呈现&#xff0c;帮助理解亿万并发场景下的核心策略与创新思维&#xff1a; 一、应对高并发的根本挑战&#xff1a;思维转变 1. 传统架构的局限 问题&#xff1a;传统系统追求零故障和强一致性&#xff0c;但在海…...

【Java集合】单列集合List详解

参考笔记&#xff1a; java 单列集合List 万字详解&#xff08;通俗易懂&#xff09;_java singlelist-CSDN博客 目录 前言&#xff1a; 一、概述 二、特点 三、使用集合的经典四部曲 四、List接口常用的方法 五、List接口实现类——ArrayList 六、List接口实现类——Ve…...

蓝桥刷题note13(排序)

1.冒泡排序 适用场景&#xff1a; 数据量较小&#xff1a;适用于数据量较小的情况&#xff0c;例如数组长度在 10 以内。 优点 稳定性&#xff1a;冒泡排序是一种稳定的排序算法&#xff0c;相同元素的相对顺序不会改变。 缺点 时间复杂度高&#xff1a;平均和最坏时间复杂度为…...

【AI模型核心流程】(一)大语言模型输入处理机制详解与常见误解辨析

一、引言 大语言模型&#xff08;LLM&#xff09;如GPT、BERT、LLaMA等&#xff0c;已成为自然语言处理领域的核心技术。然而&#xff0c;许多开发者对其底层输入处理机制存在误解&#xff0c;尤其是从自然语言文本到模型可理解的向量表示这一过程。本文将从技术细节出发&…...

如何完整迁移 Git 仓库 ?

Git 已经成为软件开发中版本控制和协作的事实上的标准。有时&#xff0c;开发人员可能需要将整个 Git 存储库 (包括其历史记录、分支和标记) 移动到新的位置或托管服务。在这个全面的指南中&#xff0c;我们将讨论在不丢失任何关键数据或历史记录的情况下无缝地重新定位完整 Gi…...

《在 Ubuntu 22.04 上安装 CUDA 11.8 和 Anaconda,并配置环境变量》

安装 CUDA 11.8 和 Anaconda 并配置环境变量 在本教程中&#xff0c;我们将介绍如何在 Ubuntu 22.04 上安装 CUDA 11.8 和 Anaconda&#xff0c;并配置相应的环境变量。我们还将配置使用 阿里云镜像源 来加速软件包更新。以下是具体步骤。 步骤 1&#xff1a;更新软件源 首先…...

残差神经网络(ResNet)概念解析与用法实例:简洁的图像处理任务

目录 1. 前言 2. ResNet的核心思想 2.1 残差学习 2.2 跳跃连接 3. ResNet的架构 3.1 残差块 3.2 ResNet的整体架构 4. ResNet实例&#xff1a;随便处理处理图像 5. 总结 1. 前言 随着深度学习的发展&#xff0c;神经网络的层数不断增加&#xff0c;但随之而来的是梯度…...

家里网络访问Github有时候打不开,解决办法

1、修改Hosts文件修改法 通过DNS查询工具&#xff08;如&#xff09;获取最新GitHub域名解析IP修改系统hosts文件&#xff08;路径&#xff1a;C:\Windows\System32\drivers\etc\hosts&#xff09;&#xff0c;添加&#xff1a;20.205.243.166 github.com 20.27.177.113 github…...

VirtualBox 配置双网卡(NAT + 桥接)详细步骤

在 VirtualBox 中为 CentOS 虚拟机配置双网卡&#xff08;NAT 桥接&#xff09;&#xff0c;使其既能访问外网&#xff08;NAT&#xff09;&#xff0c;又能与宿主机&#xff08;Windows 10&#xff09;或局域网通信&#xff08;桥接&#xff09;。 步骤 1&#xff1a;关闭虚…...

【2023】ORIGIN或MATLAB 颜色图,等高图,颜色条——需要拟合补全中间的颜色

前言 不是我疯了,就是世界疯了。我不知道究竟是哪一个疯了。瓶口和瓶盖尺寸不符。也许该怪瓶子,也许该怪盖子。但不管怎样,尺寸不符的事实不容动摇——《1Q84》 \;\;\;\;\;\; 有十几二十个导出的曲线数据,其中第一列是频率点,大约1001个,第二列是某种数据,都在0~1之间…...

flutter 专题 七十三Flutter打包未签名的ipa

在Flutter项目开发完成之后&#xff0c;需要把iOS项目拿给第三方&#xff08;如打包机&#xff09;进行签名&#xff0c;那我们首先就需要准备打包好未签名的的ipa包。 打包之前&#xff0c;需要先从第三方获取到iOS证书(.p12)和描述文件(.mobileprovision)&#xff0c;然后然…...

ngx_get_full_name

定义在 src\core\ngx_file.c ngx_int_t ngx_get_full_name(ngx_pool_t *pool, ngx_str_t *prefix, ngx_str_t *name) {size_t len;u_char *p, *n;ngx_int_t rc;rc ngx_test_full_name(name);if (rc NGX_OK) {return rc;}len prefix->len;#if (NGX_WIN32)if (…...

leetcode-代码随想录-链表-链表总结篇

理论基础 链表&#xff1a; 每个节点由两部分组成&#xff1a;数据域和指针域&#xff08;存放指向下一个节点的指针&#xff09;&#xff1b;入口节点称为头节点&#xff1b;最后一个节点的指针域指向NULL&#xff08;空指针&#xff09;。 分类&#xff1a; 单链表双链表&…...

如何用Python轻松实现快速复制或剪切文件列表中的所有文件呢?

在程序开发的过程中&#xff0c;处理文件是我们日常工作中一个很重要的环节。想象一下&#xff0c;当你需要把一大堆文件从一个文件夹移动到另一个文件夹时&#xff0c;手工操作真的会让人觉得烦躁对吧&#xff1f;这时&#xff0c;用代码来处理这些烦恼&#xff0c;真是太方便…...

【棒垒球规则】全国幼儿软式棒垒球比赛规则(二)·棒球1号位

幼儿棒垒球设备 2.01 球棒 球棒使用组委会提供的泡棉发泡安全球棒&#xff0c;以安全环保材料制成&#xff1b;球棒规格&#xff1a;长度为 53 厘米&#xff0c;重量为 200 克&#xff08;10 克&#xff09;&#xff0c;棒头直径为 7 厘米&#xff0c;握把直径为 3 厘米。 2…...

在MacOS 10.15上使用MongoDB

这次是在MacOS 10.15上使用MongoDB。先在豆包问支持MacOS 10.15的MongoDB最新版是什么&#xff0c;答案是MongoDB 5.0。 抱着谨慎怀疑的态度去官方网站查询了一下&#xff0c;答案如下 MongoDB 7.x支持的最低版本MacOS是11MongoDB 6.x支持的最低版本MacOS是10.14 又找deepsee…...

【Ragflow】11. 文件解析流程分析/批量解析实现

概述 本文继续对ragflow文档解析部分进行分析&#xff0c;并通过脚本的方式实现对文件的批量上传解析。 文件解析流程 文件解析的请求处理流程大致如下&#xff1a; 1.前端上传文件&#xff0c;通过v1/document/run接口&#xff0c;发起文件解析请求 2.后端api\apps\docum…...

企业供应链管理

企业供应链管理 企业供应链管理 企业供应链管理企业信息化信息化的作用信息化的发展阶段信息化建设的挑战 SRM&#xff08;供应商关系管理&#xff09;SRM架构参考图企业内部系统协作&#xff1a; ERP (企业资源计划)OA (办公自动化)业务功能模块&#xff1a;企业日常办公 EMS …...

性能测试之jmeter的基本使用

简介 Jmeter是Apache的开源项目&#xff0c;基于Java开发&#xff0c;主要用于进行压力测试。 优点&#xff1a;开源免费、支持多协议、轻量级、功能强大 官网&#xff1a;https://jmeter.apache.org/index.html 安装 安装步骤&#xff1a; 下载&#xff1a;进入jmeter的…...

常见的微信个人号二次开发功能

一、常见开发功能 1. 好友管理 好友列表维护 添加/删除好友 修改好友信息&#xff08;备注、标签等&#xff09; 分组管理 创建/编辑/删除标签 好友分类与筛选 2. 消息管理 信息发送 支持多类型内容&#xff1a;文本、图片、视频、文件、小程序、名片、URL链接等 附加功…...

Muduo网络库实现 [十三] - HttpRequest模块

目录 设计思路 成员设计 模块实现 设计思路 首先我们要先知道HTTP的请求的流程是什么样子的&#xff0c;不然我们会学的很迷糊。对于HTTP请求如何到来以及去往哪里&#xff0c;我们应该很清楚的知道 HTTP请求在服务器系统中的传递流程是一个多层次的过程: 客户端发起请求…...

探索C++11:解锁现代编程(3)

1.包装器 1.1function std::function 是 C 标准库中的一个模板类&#xff0c;位于 <functional> 头文件中。它用于封装可调用对象&#xff0c;包括普通函数、Lambda 表达式、函数对象、成员函数等。std::function 提供了极大的灵活性&#xff0c;使得你可以将不同类型的…...

软件工程(应试版)图形工具总结(二)

遇到的问题&#xff0c;都有解决方案&#xff0c;希望我的博客能为你提供一点帮助。 教材参考《软件工程导论&#xff08;第六版&#xff09;》 七、 层次图&#xff08;H图&#xff09;与HIPO图 1、概述 1.1、层次图&#xff08;Hierarchy Chart / H图&#xff09; ​核心…...

人工智能在前端开发中的应用探索

一、人工智能在前端开发中的应用场景 人工智能&#xff08;AI&#xff09;技术的快速发展为前端开发带来了新的机遇和挑战。AI在前端开发中的应用主要集中在以下几个方面&#xff1a;智能代码生成、自动化测试、个性化推荐、智能交互设计以及性能优化。这些应用场景不仅提高了…...

木马学习记录

一句话木马是什么 一句话木马就是仅需要一行代码的木马&#xff0c;很简短且简单&#xff0c;木马的函数将会执行我们发送的命令 如何发送命令&#xff06;发送的命令如何执行? 有三种方式&#xff1a;GET&#xff0c;POST&#xff0c;COOKIE&#xff0c;一句话木马中用$_G…...

WebSocket 也有跨域问题?如何让 Spring Boot WebSocket 允许跨域连接?

前言 在现代 Web 开发中&#xff0c;跨域问题一直是开发者必须面对的挑战。无论是传统的 HTTP 请求还是实时通信的 WebSocket&#xff0c;浏览器的同源策略&#xff08;Same-Origin Policy&#xff09;都可能成为功能实现的拦路虎。许多开发者对 HTTP 的跨域解决方案&#xff…...

音视频入门基础:MPEG2-PS专题(8)——使用Wireshark分析GB28181的PS流

音视频入门基础&#xff1a;MPEG2-PS专题系列文章&#xff1a; 音视频入门基础&#xff1a;MPEG2-PS专题&#xff08;1&#xff09;——MPEG2-PS官方文档下载 音视频入门基础&#xff1a;MPEG2-PS专题&#xff08;2&#xff09;——使用FFmpeg命令生成ps文件 音视频入门基础…...

Bash详解

各类资料学习下载合集 ​​https://pan.quark.cn/s/8c91ccb5a474​​ Bash详解 Bash(Bourne Again SHell)是Linux和Unix系统中最常用的命令行解释器之一。它不仅提供了强大的命令行操作功能,还支持脚本编程,使得用户能够自动化任务和实现复杂的操作。本文将详细介绍Bash…...

WORD+VISIO输出PDF图片提高清晰度的方法

WORDVISIO输出PDF图片提高清晰度的方法 part 1: visio 绘图part 2: word 导出 part 1: visio 绘图 先在visio中把图片和对应的文字调整为适合插入到文章中的尺寸&#xff1b; 在visio中把所有元素进行组合&#xff1b; 把组合后的图片长和宽等比例放缩&#xff0c;如放大10倍…...

springMVC--Controller配置总结

控制器Controller 控制器复杂提供访问应用程序的行为&#xff0c;通常通过接口定义或注解定义两种方式 控制器负责解析客户的请求并转换成一个模型 在springMVC中&#xff0c;一个控制器类可以包含多种方法 在springMVC中&#xff0c;对于controller的配置有多种 实现Contr…...

JavaScript BOM核心对象、本地存储

目录 BOM 核心对象详解 一、location 对象 1. 常用属性 2. 常用方法 3. 应用场景 二、navigator 对象 1. 核心属性 2. 常用方法 3. 应用场景 三、history 对象 1. 核心属性和方法 2. 应用场景 四、兼容性与注意事项 五、总结 本地存储与复杂数据类型处理 一、本…...

单元测试之测试覆盖率-jacoco基本使用

简介 免费的、开源的、针对java的单元测试覆盖率工具。基于字节码&#xff0c;无需源码也可以工作。 代码覆盖率&#xff1a;用来衡量测试代码对功能代码的测试情况&#xff0c;量化说明测试的充分度。通过执行测试用例&#xff0c;功能代码中的哪些行被执行了&#xff0c;哪…...

css3.31面试题

CSS 相关的面试题一般围绕基础知识、布局、性能优化、兼容性、深入原理等几个方向。以下是一些常见的面试题总结&#xff1a; CSS 基础知识 盒模型&#xff08;Box Model&#xff09;是什么&#xff1f;有哪些类型&#xff1f; px、em、rem、vw、vh、% 的区别&#xff1f; …...

Nature Electronics|一种透气、可拉伸的液态金属基3D电子皮肤系统(健康监测/可穿戴电子/透汗透气性电子/电子皮肤/柔性电子/集成电路)

一、 摘要 穿戴式和皮肤电子设备的发展要求高密度可伸展电子系统能够与软组织共形,持续运行并提供长期的生物相容性。大多数可拉伸电子系统的集成密度低,并且与外部印刷电路板连接,这限制了功能,降低了用户体验并阻碍了长期可用性。在此,作者提出了一种可渗透的三维集成电…...

【家政平台开发(15)】解锁Spring Boot:家政平台后端开发全攻略

本【家政平台开发】专栏聚焦家政平台从 0 到 1 的全流程打造。从前期需求分析&#xff0c;剖析家政行业现状、挖掘用户需求与梳理功能要点&#xff0c;到系统设计阶段的架构选型、数据库构建&#xff0c;再到开发阶段各模块逐一实现。涵盖移动与 PC 端设计、接口开发及性能优化…...

AI Agent设计模式二:Parallelization

概念 &#xff1a;并行任务执行引擎 ✅ 优点&#xff1a;提升吞吐量&#xff0c;充分利用多核资源❌ 缺点&#xff1a;复杂度高&#xff0c;存在竞态条件风险 from langchain_openai import ChatOpenAI from langgraph.graph import StateGraph, START, END from typing impor…...

Upload-labs靶场通关

之前搭好了靶场&#xff0c;Upload-labs 靶场搭建 及一句话木马的原理与运用-CSDN博客 今天开始通关并写详细流程 Pass-1 来到靶场的第一关 先随便上传php 代码 点击上传 发现文件类型被限制了 方法1&#xff1a; 改文件后缀为合法文件&#xff08;.jpg .png .gif&#xf…...

Python数据结构之有序列表

一.基本介绍 在有序列表中&#xff0c;元素的相对位置取决于它们的基本特征。它们通常以升序或者降序排列&#xff0c;并且我们假设元素之间能进行有意义的比较。有序列表和无序列表(链表)的许多操作都是相同的。 二.代码实现 class OrderedList:"""有序列表类…...

LMK04828使用指南-01-简介与引脚功能描述

简介 LMK0482x系列是业界性能最高的时钟调节器&#xff0c;支持JEDEC JESD204B。 PLL2的14个时钟输出可以配置为使用设备和SYSREF时钟驱动七个JESD204B转换器或其他逻辑设备。可以使用直流和交流耦合提供SYSREF。不限于JESD204B应用&#xff0c;14个输出中的每一个都可以单独…...

统计学基本原理

目录 文章目录 目录统计学统计学基本概念描述性统计数据可视化图表工具 汇总统计统计数据的分布情况&#xff1a;中位数、众数、平均值统计数据的离散程度&#xff1a;极差、方差、标准差、离散系数 相关分析Pearson 线性关系相关系数Spearman 单调关系相关系数 回归分析回归模…...

日常真实工作环境,Mysql常用操作命令,笔记!

1、开放增删改查权限&#xff0c;不开放表结构修改权限 有许多生产环境是不需要修改表结构的&#xff0c;也是为了防止SQL注入。 创建用户 mysql> grant all on *.* to ie% identified by test1设置权限 1.首先我们先回收所有权限。 revoke all on *.* from ie% ;2.设…...

洛谷题单3-P1307 [NOIP 2011 普及组] 数字反转-python-流程图重构

题目描述 给定一个整数 N N N&#xff0c;请将该数各个位上数字反转得到一个新数。新数也应满足整数的常见形式&#xff0c;即除非给定的原数为零&#xff0c;否则反转后得到的新数的最高位数字不应为零&#xff08;参见样例 2&#xff09;。 输入格式 一个整数 N N N。 …...

洛谷题单3-P1420 最长连号-python-流程图重构

题目描述 输入长度为 n n n 的一个正整数序列&#xff0c;要求输出序列中最长连号的长度。 连号指在序列中&#xff0c;从小到大的连续自然数。 输入格式 第一行&#xff0c;一个整数 n n n。 第二行&#xff0c; n n n 个整数 a i a_i ai​&#xff0c;之间用空格隔开…...