逃亡路径

2024-01-29 19:48
文章标签 路径 逃亡

本文主要是介绍逃亡路径,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

由于不能与Garfield和睦相处,Odie决定逃亡。不幸的他逃到了一个矩形湖泊。湖泊的长为N,宽为M,初始时Odie位于位置(1,1)。Garfield想要知道可怜的Odie有到达位置(N,M)的最短路径条数(不能跳出湖泊边界)。另外,神奇的Odie移动方式类似国际象棋的骑士。

输入

两个整数N和M,表示湖泊的长和宽。
输出

一个整数,表示最短路径的条数(模9901输出即可)。
输入样例

3 3

输出样例

2
说明

对于50%的数据,N ≤ 5,
对于100%的数据,N ≤ 100。

.
.
.
.
.
.
分析
注意题目要求的是最短的路径的条数
直接bfs即可

.
.
.
.
.
程序(70分的dfs):

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;int n,m,minn=2147483647,ans=0;
bool f[110][110];
int dx[8]={-2,-2,-1,-1,1,1,2,2};
int dy[8]={1,-1,2,-2,2,-2,-1,1};void dfs(int x,int y,int w)
{if (w>minn) return;if (x==n&&y==m){if (w<minn){minn=w;ans=0;}ans=(ans+1)%9901;return;}for (int i=0;i<=7;i++)if (f[x+dx[i]][y+dy[i]]==false&&x+dx[i]>=1&&x+dx[i]<=n&&y+dy[i]>=1&&y+dy[i]<=m){f[x+dx[i]][y+dy[i]]=true;dfs(x+dx[i],y+dy[i],w+1);f[x+dx[i]][y+dy[i]]=false;}
}int main()
{scanf("%d%d",&n,&m);memset(f,false,sizeof(f));f[1][1]=true;dfs(1,1,0);printf("%d",ans%9901);return 0;
}

.
.
.
.
.
.
程序(100分的bfs):

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;int n,m,a[110][110],d[110][110];
bool f[110][110];
int dx[8]={-2,-2,-1,-1,1,1,2,2};
int dy[8]={1,-1,2,-2,2,-2,-1,1};
queue<int>qx,qy;void bfs()
{qx.push(1);qy.push(1);while(!qx.empty()){int x=qx.front();qx.pop();int y=qy.front();qy.pop();f[x][y]=false;for (int i=0;i<=7;i++){int ax=x+dx[i],ay=y+dy[i];if (ax<1||ay<1||ax>n||ay>m) continue;if (d[ax][ay]>d[x][y]+1){d[ax][ay]=d[x][y]+1;if (!f[ax][ay]){f[ax][ay]=1;qx.push(ax);qy.push(ay);}a[ax][ay]=a[x][y];} elseif (d[ax][ay]==d[x][y]+1) a[ax][ay]=(a[x][y]+a[ax][ay])%9901;}}
}int main()
{scanf("%d%d",&n,&m);memset(f,false,sizeof(f));f[1][1]=true;memset(d,0X3f,sizeof(d));d[1][1]=0;a[1][1]=1;bfs();printf("%d",a[n][m]);return 0;
}

这篇关于逃亡路径的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/657994

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

VSCode设置python SDK路径的实现步骤

《VSCode设置pythonSDK路径的实现步骤》本文主要介绍了VSCode设置pythonSDK路径的实现步骤,包括命令面板切换、settings.json配置、环境变量及虚拟环境处理,具有一定... 目录一、通过命令面板快速切换(推荐方法)二、通过 settings.json 配置(项目级/全局)三、

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

如何更改pycharm缓存路径和虚拟内存分页文件位置(c盘爆红)

《如何更改pycharm缓存路径和虚拟内存分页文件位置(c盘爆红)》:本文主要介绍如何更改pycharm缓存路径和虚拟内存分页文件位置(c盘爆红)问题,具有很好的参考价值,希望对大家有所帮助,如有... 目录先在你打算存放的地方建四个文件夹更改这四个路径就可以修改默认虚拟内存分页js文件的位置接下来从高级-

一文详解如何查看本地MySQL的安装路径

《一文详解如何查看本地MySQL的安装路径》本地安装MySQL对于初学者或者开发人员来说是一项基础技能,但在安装过程中可能会遇到各种问题,:本文主要介绍如何查看本地MySQL安装路径的相关资料,需... 目录1. 如何查看本地mysql的安装路径1.1. 方法1:通过查询本地服务1.2. 方法2:通过MyS

Python如何调用指定路径的模块

《Python如何调用指定路径的模块》要在Python中调用指定路径的模块,可以使用sys.path.append,importlib.util.spec_from_file_location和exe... 目录一、sys.path.append() 方法1. 方法简介2. 使用示例3. 注意事项二、imp