蓝桥杯专题 bfs习题详解

1.离开中山路

 

#include<iostream>
#include<cstring>
#include<queue>
#include<algorithm>
#include<string>
using namespace std;
int x1,x2,y1,y2;
int n,n1,m1;
const int N=1010;typedef pair<int,int> PII;
queue<PII> q;int dist[N][N];
char g[N][N];int dx[]={-1,0,1,0};
int dy[]={0,1,0,-1};int bfs(int x1,int y1)
{memset(dist,-1,sizeof dist);q.push({x1,y1});//注意格式 dist[x1][y1]=0;while(!q.empty()){PII t=q.front();q.pop();for(int i=0;i<4;i++){n1=dx[i]+t.first;m1=dy[i]+t.second;if(n1<1||n1>n||m1<1||m1>n) continue;if(g[n1][m1]=='1') continue;if(dist[n1][m1]>0) continue;q.push({n1,m1});dist[n1][m1]=dist[t.first][t.second]+1;// ***if(n1==x2&&m1==y2){return dist[x2][y2];}}}return dist[x2][y2];
}int main()
{scanf("%d",&n);for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){cin>>g[i][j];//scanf("%c",&g[i][j]);}}scanf("%d %d %d %d",&x1,&y1,&x2,&y2);int res=bfs(x1,y1);cout<<res;return 0;} 

2.马的遍历

 

//马的遍历
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
/*如何用数组模拟队列:省时间 
对头hh,队尾tt 实现队列的插入操作:q[tt++]=x;x是要插入的数字实现队列的弹出操作:hh++;如何给队列判空:当hh++<=tt int hh=0,tt=0;*/typedef pair<int,int> PII;const int N=410;int n,m;int dist[N][N];PII q[N*N];int dx[]={2,2,1,1,-1,-1,-2,-2};int dy[]={-1,1,2,-2,2,-2,1,-1};void bfs(int x1,int y1){memset(dist,-1,sizeof dist);q[0]={x1,y1};dist[x1][y1]=0;int hh=0,tt=0;while(hh<=tt){PII t=q[hh++];//t=q.front,why++?//hh++;//pop//t=q[hh++];for(int i=0;i<8;i++){int a=t.first+dx[i];int b=t.second+dy[i];if(a<1||a>n||b<1||b>m) continue;if(dist[a][b]>=0) continue;dist[a][b]=dist[t.first][t.second]+1;q[++tt]={a,b};//}}}int main()
{int x1,y1;scanf("%d %d %d %d",&n,&m,&x1,&y1);bfs(x1,y1);for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){printf("%-5d",dist[i][j]);//%-5d左补空格,右对齐 }cout<<endl;	}return 0;
}

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

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

相关文章

GIS软件应用(二)

任务&#xff1a; 1. 正确划分渔网并裁剪出研究区域 2. 渔网与poi数据正确空间链接并统计网格内类别POI数量 步骤&#xff1a; 将南京市边界进行投影变换&#xff0c;具体看我的这篇文章&#xff1a;GIS软件应用&#xff08;一&#xff09;-CSDN博客 选择ArcToolbox中的 Cr…

海豚调度系列之:集群部署(Cluster)

海豚调度系列之&#xff1a;集群部署Cluster 一、前置准备工作二、准备 DolphinScheduler 启动环境1.配置用户免密及权限2.配置机器 SSH 免密登陆3.启动 zookeeper4.初始化数据库5.修改相关配置5.修改 dolphinscheduler_env.sh 文件 三、启动DolphinScheduler四、登录 DolphinS…

3.Linux/UNIX平台Python的下载、安装和配置环境变量——《跟老吕学Python编程》

3.Linux/UNIX平台Python的下载、安装和配置环境变量——《跟老吕学Python编程》 一、下载Linux/UNIX版Python1.Python官网2.Linux/UNIX版Python下载网址 二、在Linux/UNIX安装Python1.在Ubuntu Linux安装Python1.1 检查Python版本1.2 高级包管理工具1.3 添加存储库1.4 更新软件…

HTML静态网页成品作业(HTML+CSS)——电影肖申克的救赎介绍设计制作(1个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有1个页面。 二、作品演示 三、代…

【Flink SQL】Flink SQL 基础概念:SQL 动态表 连续查询

Flink SQL 基础概念&#xff1a;SQL 动态表 & 连续查询 1.SQL 应用于流处理的思路2.流批处理的异同点及将 SQL 应用于流处理核心解决的问题3.SQL 流处理的输入&#xff1a;输入流映射为 SQL 动态输入表4.SQL 流处理的计算&#xff1a;实时处理底层技术 - SQL 连续查询5.SQL…

Netty架构详解

文章目录 概述整体结构Netty的核心组件逻辑架构BootStrap & ServerBootStrapChannelPipelineFuture、回调和 ChannelHandler选择器、事件和 EventLoopChannelHandler的各种ChannelInitializer类图 Protocol Support 协议支持层Transport Service 传输服务层Core 核心层模块…

Windows C++ 使用WinAPI实现RPC

demo下载地址&#xff1a;https://download.csdn.net/download/2403_83063732/88958730 1、创建IDL文件以及acf文件&#xff08;创建helloworld.idl helloworld.acf&#xff09; 其中IDL文件&#xff1a; import "oaidl.idl"; import "ocidl.idl"; [ …

uView Slider 滑动选择器

该组件一般用于表单中&#xff0c;手动选择一个区间范围的场景。 说明 该组件在H5&#xff0c;微信小程序和APP-VUE等平台上使用了WXS技术&#xff0c;在NVUE平台使用了BindingX技术&#xff0c; 故在滑动过程中可以获得细腻流畅的跟随效果。 #平台差异说明 App&#xff08…

字符串和字节的使用

字符串和字节的使用 学习目标&#xff1a; 了解 常见字符以及字符集掌握 str&#xff0c;bytes以及互相转换的方法 1 字符、字符集 字符(Character)是各种文字和符号的总称&#xff0c;包括各国家文字、标点符号、图形符号、数字等 字符集(Character set)是多个字符的集合 …

【LeetCode热题100】73. 矩阵置零(矩阵)

一.题目要求 给定一个 m x n 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 二.题目难度 中等 三.输入样例 示例 1&#xff1a; 输入&#xff1a;matrix [[1,1,1],[1,0,1],[1,1,1]] 输出&#xff1a;[[1,0…

2024考研计算机考研复试-每日重点(第二十期)

公众号“准研计算机复试”&#xff0c;超全大佬复试资料&#xff0c;保姆级复试&#xff0c;80%的题目都是上岸大佬提供的。 研宝们&#xff0c;App更新啦&#xff01; 计算机组成原理&#xff1a; 10.☆什么是数据存储的大端模式和小端模式&#xff1f; 大端模式&#xff1a;数…

github拉取项目找不到前端代码

今天从github上拉取了一个项目&#xff0c;使用docker部署在了服务器上&#xff0c; 代码正常运行&#xff0c;但是想在下载的项目中找前端代码遇到了问题&#xff0c;项目结构中的template模板只有一个页面&#xff0c;于是查看nginx配置文件 查看index.html 引入了一些js文件…

c++11 标准模板(STL)(std::locale)(四)返回 locale 的名称

用以封装文化差异的多态刻面的集合 std::locale 类型对象是不可变平面的不可变索引集。 C 输入/输出库的每个流对象与一个 std::locale 对象关联&#xff0c;并用其平面分析及格式化所有数据。另外&#xff0c; locale 对象与每个 std::basic_regex 对象关联。 locale 对象亦可…

使用Julia及R语言生成正态分布的随机数字并写入CSV文件

在操作之前需要先下载Julia的Distributions包&#xff0c;这个包用于进行相关概率分布的函数调用。 在输入 ] 进入Julia包管理模式后输入&#xff1a; add Distributions 这里我使用我们自己实验室的实测数据 &#xff0c;平均值0.67&#xff0c;方差0.11&#xff0c;数据分…

聚氨酯封孔剂因为热爱

忙忙碌碌又一天,对每个顾客都用心服务,因为热爱,所以不辛苦,因为热爱,即使无数遍的重复也不会厌倦。 聚氨酯封孔材料的主要性能特点&#xff1a; 1、粘度低&#xff0c;易渗入微小裂隙&#xff1b; 2、粘合能力很强&#xff0c;具有持久强粘结性&#xff1b; 3、柔韧性.越&am…

HCIP —— BGP 路径属性 (上)

目录 BGP 路径属性 1.优选Preferred-Value属性值最大的路由 2.优选Local-preference 属性数值大的路由 3.本地始发的BGP路由优先于其他对等体处学习到的路由。 4..优选AS_PATH属性值最短的路由 BGP 路径属性 BGP的路由选路是存在优选规则的&#xff0c;下图为华为官网提供…

2 配置虚拟机

1.打开VM&#xff0c;主页的界面如下&#xff0c;点击"创建新的虚拟机" 2.选择“自定义&#xff08;高级&#xff09;”&#xff0c;然后点击下一步&#xff0c;如下图所示&#xff1a; 3.下图直接点击“下一步” 4.下图的界面上&#xff0c;注意&#xff0c;不要选择…

用python实现人生重开模拟器游戏

人生重开模拟器是一款非常有趣的游戏&#xff0c;它让玩家能够模拟人生的各种可能性和选择。在Python中实现这个游戏&#xff0c;我们可以采用文本界面的形式&#xff0c;并使用随机数来模拟人生的不同事件。 以下是一个简化版的人生重开模拟器的Python实现&#xff1a; pytho…

3.11笔记2

目前使用的格里高利历闰年的规则如下&#xff1a; 公元年分非4的倍数&#xff0c;为平年。公元年分为4的倍数但非100的倍数&#xff0c;为闰年。公元年分为100的倍数但非400的倍数&#xff0c;为平年。公元年分为400的倍数为闰年。 请用一个表达式 (不能添加括号) 判断某一年…

【STL】stack栈容器与list链表容器

1.栈stack 栈具有先进后出的特性&#xff0c;最先进入的数据压在最底下&#xff0c;最后出来 2.list链表容器 list链表容器是一种双向链表&#xff0c;两端都可插入与删除&#xff0c;是双向访问迭代器&#xff0c;与vertor随机访问迭代器有不同的区别 reverse&#xff08;&…