| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> C++知识库 -> 蓝桥杯(跳马问题)【15ms2.531MB】 -> 正文阅读 |
|
[C++知识库]蓝桥杯(跳马问题)【15ms2.531MB】 |
【问题描述】一个8Ⅹ8的棋盘上有一个马初始位置为(a,b),他想跳到(c,d),问是否可以?如果可以,问最少要跳几步? 【输入格式】一行数字a,b,c,d。 【输出格式】如果跳不到,输出-1;否则输出最少跳到的步数。 【样例输入】1 1 2 3 【样例输出】1 【数据规模和约定】0<a,b,c,d<=8且都是整数 【思路】理论上只要一直走下去,每个点都能走到,所以不存在走不到的点。 建立一个二维数组path[][],大小为9*9,用来存放到达该点所需要的最少步数 初始化数组每个元素为0,起点为-1,便于区分 其中每走一步都有8种走法: ----x+1,y+2(x+1<=8,y+2<=8) ----x-1,y+2(x-1>=0,y+2<=8) ----x+2,y+1(x+1<=8,y+2<=8) ----x-2,y+1(x+1>=0,y+2<=8) ----x+1,y-2(x+1<=8,y+2>=0) ----x-1,y-2(x-1>=0,y+2>=0) ----x+2,y-1(x+1<=8,y+2>=0) ----x-2,y-1(x+1>=0,y+2>=0) 定义初始步数为0,从起点开始所走的一步令其数组元素为n+1,以此类推;如果该点的值不为0,则不改变该点的元素值。 注意:输入的点为平面直角系的坐标,大小是从左到右,从下到上 而二维数组的大小是从左到右,从上到下。 但是这不影响最终结果,就是上下颠倒而已 a,c为横坐标,对应二维数组中的一维;b,d为纵坐标,对应二维数组中的二维。 写出来就是path[b][a],path[d][c]。编程的时候特别注意。
|
|
C++知识库 最新文章 |
【C++】友元、嵌套类、异常、RTTI、类型转换 |
通讯录的思路与实现(C语言) |
C++PrimerPlus 第七章 函数-C++的编程模块( |
Problem C: 算法9-9~9-12:平衡二叉树的基本 |
MSVC C++ UTF-8编程 |
C++进阶 多态原理 |
简单string类c++实现 |
我的年度总结 |
【C语言】以深厚地基筑伟岸高楼-基础篇(六 |
c语言常见错误合集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/24 9:39:04- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |