BFS入门

目录

  • 定义
  • 二叉树层次遍历
  • 电梯问题
  • 倒可乐
  • BFS基本思想
    • 算法
  • 四方访问

定义

BFS 通常是指广度优先搜索(Breadth - First Search),它是一种图形数据结构的遍历算法。从给定的起始顶点开始,首先访问起始顶点的所有邻接顶点,然后再依次访问这些邻接顶点的邻接顶点,以此类推,一层一层地向外扩展搜索,就好像是水波纹一样,从中心向四周扩散。在这个过程中,先被访问到的顶点的邻接顶点会先被探索。

二叉树层次遍历

在这里插入图片描述

ccbl(int root)queue<int> Q; //创建一个队列Q.push(root); //将根节点入队列while(!empty(Q) //队列不为空){cur = Q.gethead;  //获得队首元素Q.pop();  //将队首元素出队printf("%d",cur);  //输出当前节点的值if(!Q.leftchild)Q.push(Q.leftchild);  //如果该节点的左儿子不为空,将左儿子加入到队列中if(!Q.rightchild)Q.push(Q.rightchild);  //如果该节点的右儿子不为空,将右儿子加入到队列中}

电梯问题

有一个奇怪的电梯,他可以停在任何不层,并且在每个楼层有一个Ki (0<= Ki <=N)。电梯只有两个按钮:上、下。当你在第i层,如果你按下“UP”按钮,你将上升Ki层,也就是说,你将会到达第i+Ki层,如果你按下 “DOWN” 按钮,你会下降Ki层,即您将前往第i-Ki层。当然,电梯不能高于N,也不能低于1。
例如,有6层的建筑物,并且k1=3,k2=3,k3=2,k4=2,k5=2,k6=3。从1楼开始,你河以按下“UP”按钮,你会到4楼,但如果你按下“DOWN”按钮,电梯不做处理,因为它不能下到-2楼。
问:当你在A楼而想去B楼时,至少须按下“UP”或“DOWN”按钮多少次?其中,1<=N,A, B <= 200
样例输入:
6 1 3
3 3 2 2 2 З
样例输出:
3

在这里插入图片描述

#include<bits/stdc++. h> using namespace std;
int N,Start, End; int a[202]; int vis[202];
struct pos
{
int level; 
int steps;
}void bfs();int main
{while (scanf ("%d", &N) ==1){if (N = 0) break;scanf ("%d%d", &Start, &End) ;for (int i = 1; i < N; i++){scanf ("%d", &a[i]);vis[i] = 0;}bfs ();}return 0;
}void bfs ()
{pos cur, nex;cur. level = Start;cur. steps = 0;queue<pos>qu;qu. push (cur) ;vis[Start] = 1;while (!qu. empty ()){ cur = qu. front ();qu. pop () ;if (cur. level = End){ printf ("%d\n", cur. steps);return;}nex. level=cur. level + a[cur. level];nex. steps = cur. steps + 1;if(nex. level <= N){if (vis[nex. level] == 0){vis [nex. level] = 1;qu. push (nex);}}nex.level = cur.level - a[ cur.level ];nex. steps = cur. steps + 1;if(nex. level >= 1){ if (vis[nex. level] == 0){vis [nex. level] = 1;qu. push (nex);}}}printf ("-1\n") ;return;
}

倒可乐

题目描述:
每当刘一丁买了可乐,刘二丁就要求和他一起分享,而且一定要喝的和刘一丁一样多。但刘一丁的手中只有两个杯子,它们的容量分别是N和M毫升,可乐的体积为S(S<101)毫升(正好装满一瓶),它们三个之间可以相互倒可乐(都是没有刻度的,且 S=N+M,101>S>0,N>0,M>0)。
如果能平分,请输出倒可乐的最少次数,如果不能,请输出"NO"。
Input
7 4 3
413
000
Output
NO
3

在这里插入图片描述

状态转移规则(倒水规则):

  1. 如果i水杯内水的容量大于j水杯内倒满所需的容量X,则i水杯倒水后的容量为:i-x,j水杯倒水后容量为:j+x
  2. 如果i水杯内水的容量小于j水杯内倒满所需的容量x,则i水杯倒水后的容量为:0,j水杯倒水后容量为:j+x
  3. 每操作一次,最少倒水次数+1

BFS基本思想

  1. 从初始状态S开始,利用规则,生成所有可能的状态,构成树的下一层节点。
  2. 检查是否出现目标状态G,若未出现,就对该层所有状态节点,分别依次利用规则,生成再下一层的所有状态节点。
  3. 对新一层的所有状态节点继续检查是否出现G,若未出现,继续按上面思想生成再下一层的所有状态节点,这样一层一层往下展开,直到出现目标状态为止。

算法

Node bfs(node source, node target)
{memset(visit, 0 , sizeof(visit)) ;queue < node> Q;Q.push(source) ;visit[source] = 1 ;while(!Q.empty){Node a = Q.front();Q.pop() ;if(a==target) { return a; }for(对于a所有的后继节点 b)if(visit[b]){ continue ; }Q.push(b) ;visit[b]= 1//剪枝,保证节点只进队列一次}return NULL;
}

四方访问

定义一个二维数组(全局变量);

int dir[4][2] = { {0,-1},{0,1},{1,0},{-1,0} };
//设当前坐标(X.Y),下步坐标(XX,YY)
forint i=0; i<4; i++)
{XX = XX + dir[i][0];YY = YY + dir[i][1];......
}

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

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

相关文章

如何将CSDN的文章保存为PDF?

目录 1、打开CSDN文章2、按F12或者鼠标右键选择检查并进入控制台3、在控制台输入以下代码4、然后回车&#xff08;Enter&#xff09;如果纵向显示不全就横向 1、打开CSDN文章 2、按F12或者鼠标右键选择检查并进入控制台 3、在控制台输入以下代码 (function(){ $("#side&q…

25考研软件工程 西南大学跟重庆大学哪个难?

需知晓&#xff0c;西南大学每年报考人数众多&#xff0c;可这不代表报考软件工程专业的人数就多呀&#xff0c;况且西南大学的优势学科并非工科&#xff0c;故而软件工程的报考热度不会如题主所言那般高呢。 其次得明白&#xff0c;软件工程专业上岸难度方面&#xff0c;重庆大…

普通算法——二维前缀和

二维前缀和 题目链接&#xff1a;https://www.acwing.com/problem/content/798/ 题目描述&#xff1a; 输入一个 n n n 行 m m m 列的整数矩阵&#xff0c;再输入 q q q 个询问&#xff0c;每个询问包含四个整数 ** x 1 , y 1 , x 2 , y 2 x1,y1,x2,y2 x1,y1,x2,y2 &…

Mock神器:Easy-Mock 私有化部署及使用介绍

在现代前后端分离的开发模式中&#xff0c;后端接口的数据模拟是一个常见且必要的需求。尤其是在后端接口尚未开发完成时&#xff0c;前端开发需要依赖模拟数据进行开发与测试。Easy-Mock 是一个非常流行的开源工具&#xff08;虽然它已经停止更新好长时间了&#xff09;&#…

Java的Mvc整合Swagger的knife4框架

Swagger的介绍 Swagger 是一个规范和完整的框架&#xff0c;用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。使用Swagger&#xff0c;就是把相关的信息存储在它定义的描述文件里面&#xff08;yml或json格式&#xff09;&#xff0c;再通过维护这个描述 文件可以去更…

01_Node.js入门 (黑马)

01_Node.js入门 知识点自测 从 index.js 出发&#xff0c;访问到 student/data.json 的相对路径如何写? A&#xff1a;../public/teacher/data.json B&#xff1a;./public/student/data.json C&#xff1a;../student/data.json <details><summary>答案</sum…

2024.12.5——攻防世界Training-WWW-Robots攻防世界baby_web

2024.12.5—攻防世界Training-WWW-Robots 知识点&#xff1a;robots协议 dirsearch工具 本题与第一道Robots协议十分类似&#xff0c;不做wp解析 大致步骤&#xff1a; step 1 打开靶机&#xff0c;发现是robots协议相关 step 2 用dirsearch进行扫描目录 step 3 url传参r…

电脑无法识别usb设备怎么办?电脑无法识别usb解决方法

usb设备是我们常解除的外部操作以及存储设备&#xff0c;它可以方便用户数据传输以及操作输入。但在使用过程中&#xff0c;大家基本都碰到过电脑无法识别usb设备这种情况。这种情况下&#xff0c;我们应该怎么办呢&#xff1f;下面将为你介绍几种可能的原因和解决方法&#xf…

【学习总结|DAY014】Java面向对象高级-继承、多态

一、继承&#xff08;Inheritance&#xff09; 1. 概述 继承是面向对象编程的一种特性&#xff0c;允许我们定义一个类&#xff08;称为子类或派生类&#xff09;以继承另一个类&#xff08;称为超类或基类&#xff09;的功能。 2. 语法格式 public class Zi extends Fu {/…

筑起厂区安全--叉车安全防护装置全解析

在繁忙的工业生产领域中&#xff0c;叉车作为搬运工&#xff0c;穿梭于仓储与生产线之间。然而&#xff0c;叉车的高效运作背后&#xff0c;也隐藏着诸多安全风险&#xff0c;尤其是在那些空间狭小、物流繁忙的环境中。为了降低这些潜在的危险&#xff0c;叉车安全防护装置便成…

MS SQL SERVER服务自动停止解决

报错原因 电脑异常重启&#xff0c;导致 MS SQL server 服务启动后自动停止&#xff0c;在【计算机管理】-【事件查看器】-【windows日志】中进行查看系统错误日志&#xff0c;在【应用程序】下发现可能的错误信息&#xff1a; 传递给数据库 ‘model’ 中的日志扫描操作的日志…

网络安全信息收集(总结)更新

目录 重点&#xff1a; 前言&#xff1a; 又学到了&#xff0c;就是我们什么时候要子域名收集&#xff0c;什么时候收集域名&#xff0c;重点应该放前面 思考&#xff1a; 信息收集分为哪几类&#xff0c;什么是主域名&#xff0c;为什么要收集主域名&#xff0c;为什么要收…

使用 Postman 上传二进制类型的图片到后端接口写法

我们有的时候会有需求&#xff0c;就是通过 postman 传递二进制图片到后端接口&#xff0c;如下图&#xff1a; 那我们的 Java 接口需要怎么写呢&#xff1f; Spring Boot 接收这些数据的方式需要使用 RequestBody 注解来处理原始的二进制数据&#xff08;byte[]&#xff09;。…

Java Web 7 请求响应(Postman)

前言&#xff08;SpringBoot程序请求响应流程&#xff09; 以上一章的程序为例&#xff0c;一个基于SpringBoot的方式开发一个web应用&#xff0c;浏览器发起请求 /hello 后 &#xff0c;给浏览器返回字符串 “Hello World ~”。 而我们在开发web程序时呢&#xff0c;定义了一…

pytorch多GPU训练教程

pytorch多GPU训练教程 文章目录 pytorch多GPU训练教程1. Torch 的两种并行化模型封装1.1 DataParallel1.2 DistributedDataParallel 2. 多GPU训练的三种架构组织方式2.2 数据不拆分&#xff0c;模型拆分&#xff08;Model Parallelism&#xff09;2.3 数据拆分&#xff0c;模型…

【opencv入门教程】9.视频加载

文章选自&#xff1a; 一、VideoCapture类 用于从视频文件、图像序列或摄像头捕获视频的类。函数&#xff1a;CV_WRAP VideoCapture();brief 默认构造函数CV_WRAP explicit VideoCapture(const String& filename, int apiPreference CAP_ANY);brief 使用 API 首选项打开…

海外的bug-hunters,不一样的403bypass

一种绕过403的新技术&#xff0c;跟大家分享一下。研究HTTP协议已经有一段时间了。发现HTTP协议的1.0版本可以绕过403。于是开始对lyncdiscover.microsoft.com域做FUZZ并且发现了几个403Forbidden的文件。 &#xff08;访问fsip.svc为403&#xff09; 在经过尝试后&#xff0…

阿里内部正式开源“Spring Cloud Alibaba (全彩小册)”

年轻的毕业生们满怀希望与忐忑&#xff0c;去寻找、竞争一个工作机会。已经在职的开发同学&#xff0c;也想通过社会招聘或者内推的时机争取到更好的待遇、更大的平台。 然而&#xff0c;面试人群众多&#xff0c;技术市场却相对冷淡&#xff0c;面试的同学们不得不面临着 1 个…

乘上 SpringBoot 东风,广场舞团掀起律动热潮

2 系统开发环境 2.1 Java技术 Java是由Sun公司推出的一门跨平台的面向对象的程序设计语言。因为Java 技术具有卓越的通用性、高效性、健壮的安全性和平台移植性的特点&#xff0c;而且Java是开源的&#xff0c;拥有全世界最大的开发者专业社群&#xff0c;所以Java的发展迅速。…

【PlantUML系列】状态图(六)

一、状态图的组成部分 状态&#xff1a;对象在其生命周期内可能处于的条件或情形&#xff0c;使用 state "State Name" as Statename 表示。初始状态&#xff1a;表示对象生命周期的开始&#xff0c;使用 [*] 表示。最终状态&#xff1a;表示对象生命周期的结束&…