集训作业 洛谷P1443 马的遍历
这个题是个搜索,而且有是最少的步数,肯定就是广搜啦,不知道为什么的同学先去学习一下广搜吧。
养成好习惯,看见最少步数就去想想广搜(只是我自己觉得)
竟然这个题可以如此顺畅的想到广搜,感觉不难啊,但还有一个奇怪的地方,
emm,这个有点冷门啊,没事,讲讲(百度一下)就知道了。
奉上百度答案:printf("%-5d",x);
这句话的意思就是左对齐,宽5格,输出x。
到这里我们几乎就全讲完了(我讲的好水,听不的懂的同学去隔壁dgdger的博客看看吧,传送门)
广搜嘛,我直接附上之前讲广搜的链接吧,广搜。
对了,还有一个马的走法,我直接上图吧

红色的实心圆是马的位置,剩下的黑实心圆是可以走到的位置,上面的红字是坐标(应该是对的)
emm,接下来的讲解就打成注释吧,要仔细看代码哦。
#include<iostream>
#include<cstdio>
using namespace std;
struct z
{
int x,y,bushu=0;
}ma[200000];//400*400=160000
int a1[10]={1,-1,1,-1,-2,-2,2,2};//这是控制马移动方向的数组,a1是x,a2是y
int a2[10]={-2,-2,2,2,-1,1,-1,1};//众所周知,马走日,所以就这样写了。
int a[500][500],book[500][500],n,m,qx,qy,zx,zy,t,w;//a是记录到达每个点最小位置的数组,book就是记忆化数组。
int main()
{
cin>>n>>m>>qx>>qy;//正常的输入
a[qx][qy]=-1;//来一波初始化,为什么要初始化成-1呢?因为这样不被走到的地方就直接是-1了,不用另外判断。
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
a[i][j]=-1;
}
}
a[qx][qy]=0;//出生点不需要走就可以到达。
book[qx][qy]=1;//来过出生点,再来就是绕路了。
t=0;//头和尾
w=0;
ma[t].x=qx;//这里我用的数组,queue也可以的。
ma[t].y=qy;//存下位置
ma[t].bushu=0;//存下步数
t++;
while(w<t)//还是有地方可以走的(目前不绕路的地方)
{
for(int i=0;i<8;i++)//马有8个走法
{
zx=ma[w].x+a1[i];//zx和zy表示这一次走完后的位置。
zy=ma[w].y+a2[i];
if(zx<=n&&zx>0&&zy<=m&&zy>0&&book[zx][zy]==0)//如果没有绕圈子,也没有越界,才可以储存
{
//绕圈子就是广搜中的记忆化搜索,大家可以学一下
book[zx][zy]=1;//现在我来过这个地方了。下次来就可以知道是绕圈子了。
ma[t].x=zx;//存下来
ma[t].y=zy;
ma[t].bushu=ma[w].bushu+1;//我从上一个地方走来,用ma[w].bushu步,走到这里用了一步,加起来就是从起点走到这里用的步数啦。
a[zx][zy]=ma[t].bushu;//这个位置是第一次来,那就一定是最小步数。
t++;
}
}
w++;//别忘了w++,重复查看一个点是会TLE的。
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
printf("%-5d",a[i][j]);//左对齐,宽5格
}
cout<<endl;
}
return 0;//完美结束
}
这个题和别的广搜没啥区别,如果你这个题过不了,希望你去学习或巩固一下广搜。
结束了……
集训作业 洛谷P1443 马的遍历的更多相关文章
- 【bfs】洛谷 P1443 马的遍历
题目:P1443 马的遍历 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 记录一下第一道ac的bfs,原理是利用队列queue记录下一层的所有点,然后一层一层遍历: 其中: 1.p ...
- 洛谷 P1443 马的遍历
P1443 马的遍历 题目描述 有一个n*m的棋盘(1<n,m<=400),在某个点上有一个马,要求你计算出马到达棋盘上任意一个点最少要走几步 输入输出格式 输入格式: 一行四个数据,棋盘 ...
- 洛谷P1443 马的遍历
https://www.luogu.org/problemnew/show/P1443 很经典的搜索题了,蒟蒻用广搜打的 不说了,上代码! #include<bits/stdc++.h> ...
- 洛谷 P1443 马的遍历
终于遇到一个简单纯粹一点的bfs了...... 题目链接:https://www.luogu.org/problemnew/show/P1443 题目是求到达一个点的最短步数 也就是说我只要bfs遍历 ...
- 洛谷 P1443 马的遍历题解
题目链接:https://www.luogu.org/problem/P1443 题目描述 有一个n*m的棋盘(1<n,m<=400),在某个点上有一个马,要求你计算出马到达棋盘上任意一个 ...
- 【洛谷P1443 马的遍历】
题目链接(%%%jyy大佬) 题目描述 有一个n*m的棋盘(1<n,m<=400),在某个点上有一个马,要求你计算出马到达棋盘上任意一个点最少要走几步 输入输出格式 输入格式: 一行四个数 ...
- 洛谷P1443马的遍历
传送 这是个广搜,思路和普通的迷宫题差不多,但我卡了3遍,为什么呢? 因为输出格式 题目要求左对齐,宽度为5输出,在此说一下如何控制宽度. 下面的m都为要求的宽度 int 类型: printf: %m ...
- 洛谷P1443 马的遍历(bfs,注意输出格式)
题目描述 有一个n*m的棋盘(1<n,m<=400),在某个点上有一个马,要求你计算出马到达棋盘上任意一个点最少要走几步 输入输出格式 输入格式: 一行四个数据,棋盘的大小和马的坐标 输出 ...
- 洛谷P1443 马的遍历【BFS】
题目描述 有一个n*m的棋盘(1<n,m<=400),在某个点上有一个马,要求你计算出马到达棋盘上任意一个点最少要走几步 输入输出格式 输入格式: 一行四个数据,棋盘的大小和马的坐标 输出 ...
随机推荐
- SpringBoot 启动配置原理
几个重要的事件回调机制 ApplicationContextInitializer SpringApplicationRunListener ApplicationRunner CommandLine ...
- GeckoDriver+Selenium+Python的安装和使用
如果没有安装GeckoDriver会提示: selenium.common.exceptions.WebDriverException: Message: 'geckodriver' executab ...
- Andrew Ng - 深度学习工程师 - Part 2. 改善深层神经网络:超参数调试、正则化以及优化(Week 2. 优化算法)
===========第2周 优化算法================ ===2.1 Mini-batch 梯度下降=== epoch: 完整地遍历了一遍整个训练集 ===2.2 理解Mini-bat ...
- springboot + rabbitmq 做智能家居,我也没想到会这么简单
本文收录在个人博客:www.chengxy-nds.top,共享技术资源,共同进步 前一段有幸参与到一个智能家居项目的开发,由于之前都没有过这方面的开发经验,所以对智能硬件的开发模式和技术栈都颇为好奇 ...
- swiper 实现滑动解锁
最近项目中有这样一个需求,研究了两种写法一个原生,一个使用框架 原生写法: <!DOCTYPE html> <html> <head> <meta chars ...
- Cannot instantiate the type Map
今天在使用Map中犯了个低级错误,记录一下: 打算使用map为一个视频List观看记录的统计标识,key为vid,value默认为false,当该key已经统计,标识value为true,初始实例化M ...
- 手把手教你使用Python生成图灵智能小伙伴,实现工作助手/闲聊功能
/1 前言/ 在家闲着,做个小项目,基于Python,实现一个语聊小机器人,分享给大家.项目整体比较简单,官方文档介绍的非常详细,可快速上手. /2 目标/ 将图灵机器人放到桌面,实现工作助手/陪聊功 ...
- java 加密与解密艺术
视频来自黑马程序员公开课 对称加密之后的密文可能存在乱码,这些乱码无法识别,信息经过加密后会变成一串毫无规律的二进制串,此时再选择一种编码方式来展示,通常是 BASE64 格式的编码. 为了解决这个问 ...
- Python实用笔记 (19)面向对象编程——访问限制
在Class内部,可以有属性和方法,而外部代码可以通过直接调用实例变量的方法来操作数据,这样,就隐藏了内部的复杂逻辑. 但是,从前面Student类的定义来看,外部代码还是可以自由地修改一个实例的na ...
- #Google HTML&CSS规范指南
Google HTML&CSS规范指南 翻译自原文 目录 Google HTML&CSS规范指南 1. 背景 2. 通用 2.1 通用样式规则 2.1.1 协议 2.2 通用格式规则 ...