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

【C++ 真题】P1747 好奇怪的游戏

P1747 好奇怪的游戏

题目背景

《爱与愁的故事第三弹·shopping》娱乐章。

调调口味来道水题。

题目描述

爱与愁大神坐在公交车上无聊,于是玩起了手机。一款奇怪的游戏进入了爱与愁大神的眼帘:***(游戏名被打上了马赛克)。这个游戏类似象棋,但是只有黑白马各一匹,在点 x 1 , y 1 x_1,y_1 x1,y1 x 2 , y 2 x_2,y_2 x2,y2 上。它们得从点 x 1 , y 1 x_1,y_1 x1,y1 x 2 , y 2 x_2,y_2 x2,y2 走到 ( 1 , 1 ) (1,1) (1,1)。这个游戏与普通象棋不同的地方是:马可以走“日”,也可以像象走“田”。现在爱与愁大神想知道两匹马到 ( 1 , 1 ) (1,1) (1,1) 的最少步数,你能帮他解决这个问题么?

注意不能走到 x x x y y y 坐标 ≤ 0 \le 0 0 的位置。

输入格式

第一行两个整数 x 1 , y 1 x_1,y_1 x1,y1

第二行两个整数 x 2 , y 2 x_2,y_2 x2,y2

输出格式

第一行一个整数,表示黑马到 ( 1 , 1 ) (1,1) (1,1) 的步数。

第二行一个整数,表示白马到 ( 1 , 1 ) (1,1) (1,1) 的步数。

输入输出样例 #1

输入 #1

12 16
18 10

输出 #1

8 
9

说明/提示

数据范围及约定

对于 100 % 100\% 100% 数据, 1 ≤ x 1 , y 1 , x 2 , y 2 ≤ 20 1\le x_1,y_1,x_2,y_2 \le 20 1x1,y1,x2,y220

题解

#include<bits/stdc++.h>
using namespace std;
const int N=1e3+7;int x11, y11, x22, y22, m, n, st = 0;
bool vis[N][N]; 
int rx[] = {0, -2, -2, -1, 1, 2, 2, 2, 2, 1, -1, -2, -2};
int ry[] = {0, -1, -2, -2, -2, -2, -1, 1, 2, 2, 2, 2, 1};//顺时针 struct pl{int x, y, s;
};queue<pl> pass;int bfs(int x, int y){if(x == 1 && y == 1) return 0;vis[x][y] = 1;while(!pass.empty()){pl pass1 = pass.front();pass.pop();for(int i=1;i<=12;++i){int nx = rx[i] + pass1.x;int ny = ry[i] + pass1.y;if(nx<=0 || nx>n || ny<=0 || ny>m || vis[nx][ny]) continue;if(nx == 1 && ny == 1) return pass1.s+1;vis[nx][ny] = 1;	pass.push({nx, ny, pass1.s+1}); }}return 0;
}int main(){cin>>x11>>y11>>x22>>y22;n = max(x11, x22)+1;m = max(y11, y22)+1;memset(vis, 0, sizeof(vis));while(!pass.empty()) pass.pop();pass.push({x11, y11, 0});cout<<bfs(x11, y11)<<endl;memset(vis, 0, sizeof(vis));while(!pass.empty()) pass.pop();pass.push({x22, y22, 0});cout<<bfs(x22, y22)<<endl;return 0;
}

相关文章:

  • 基于 STM32 的四路 PWM 控制智能小车运动的模块化控制程序
  • 垃圾回收相关八股
  • Qt学习及使用_第1部分_认识Qt---学习目的及技术准备
  • 【Linux】SSH:免密登录
  • Cursor实现用excel数据填充word模版的方法
  • 第18节 Node.js Web 模块
  • 双面沉金线路板制作流程解析:高可靠性PCB的核心工艺
  • 【数据结构初阶】单链表
  • 论文调研_BCSD综述论文调研
  • 使用 Ansible 在 Windows 服务器上安装 SSL 证书系列之二
  • SpringBoot项目接口集中测试方法及实现
  • 巴西医疗巨头尤迈Kafka数据泄露事件的全过程分析与AI安防策略分析
  • Mac软件卸载指南,简单易懂!
  • iframe(概念、简单例子、在vue项目中的使用)
  • 【Java微服务组件】分布式协调P4-一文打通Redisson:从API实战到分布式锁核心源码剖析
  • MacOS下Homebrew国内镜像加速指南(2025最新国内镜像加速)
  • GOOUUU ESP32-S3-CAM 果云科技开发板开发指南(一)(超详细!)Vscode+espidf 通过摄像头拍摄照片并存取到SD卡中,文末附源码
  • Go 语言并发编程基础:无缓冲与有缓冲通道
  • VScode 使用 git 提交数据到指定库的完整指南
  • 【Fiddler工具判断前后端Bug】
  • 网站制作的软件/搜索关键词排名查询
  • 网站开发前台和后台/营销培训机构哪家最专业
  • 上海做网站cnsosu/管理微信软件
  • 南昌做建网站的/竞价服务托管公司
  • wordpress环境系统/排名优化系统
  • 如何投诉网站制作公司/网站建设选亿企网络