C++骑士游历问题的示例分析
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,这篇文章主要介绍了C++骑士游历问题的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。骑士游历问题:在国际棋盘上使一个骑士遍历所
千家信息网最后更新 2025年11月07日C++骑士游历问题的示例分析
这篇文章主要介绍了C++骑士游历问题的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
骑士游历问题:在国际棋盘上使一个骑士遍历所有的格子一遍且仅一遍,对于任意给定的顶点,输出一条符合上述要求的路径
解题思路:
这是一道经典的遍历问题(DFS),由于题目要求遍历全部,那么肯定要做标记,因此立马想到DFS深度优先算法。具体思路如下:
①了解国际象棋以及国际象棋骑士的走法
国际象棋和中国象棋,大同小异,毕竟中国象棋是老祖先。国际象棋棋子放在格子中,中国象棋放在点上,且国际象棋有64个格子。国际象棋的骑士和中国象棋的马功能相当,都可以走八个方位。走法是走"日"字,或英文字母大写的"L"形:即先向左(或右)走1格,再向上(或下)走2格;或先向左(或右)走2格,再向上(或下)走1格。与中国象棋的馬不同,国际象棋的马可以跳过路上的其他棋子,不受拐脚的限制。
解题需要我们可以把格子抽象成一个点,那么国际象棋的骑士走法就是一个日字。
②设置标记
初始化数组,让每个元素初始化为0,并且初始化一个记录骑士遍历次数的cal也为0
int cal = 0; //统计走的顺序//初始化为0int chress[8][8] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};③判断是否超界和是否被访问
bool ifOut(int x, int y) //判断是否出界{ if (x >= 0 && x <= 7 && y >= 0 && y <= 7) return false; else return true;}bool ifVisited(int x, int y) //判断是否被访问{ if (chress[x][y] != 0) return true; else return false;}④递归主体
void dfs(int x,int y){ if (cal == 64) //如果遍历完则退出棋盘一共64个位置 return; if (!ifVisited(x, y) && !ifOut(x, y)) //如果没有被访问且没有出界 则访问 { cal++; chress[x][y] = cal; //做标记 dfs(x + 2, y + 1); //骑士走法有八个方位,故八个 方位都遍历 dfs(x - 2, y - 1); //八个递归的顺序可以改,顺序不一样,结果不一样 dfs(x + 2, y - 1); dfs(x - 2, y + 1); dfs(x - 1, y - 2); dfs(x + 1, y - 2); dfs(x + 1, y + 2); dfs(x - 1, y + 2); return; } else //else其中包括已经被访问了,和没有被访问且在界外的 return;}⑤总代码如下(编译器vs2013)
#include"stdafx.h"#include#include using namespace std;int cal = 0; //统计走的顺序//棋盘初始化为0做标记int chress[8][8] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};bool ifOut(int x, int y) //判断是否出界{ if (x >= 0 && x <= 7 && y >= 0 && y <= 7) return false; else return true;}bool ifVisited(int x, int y) //判断是否已经被访问{ if (chress[x][y] != 0) return true; else return false;}void dfs(int x,int y){ if (cal == 64) //如果遍历完则退出棋盘一共64个位置 return; if (!ifVisited(x, y) && !ifOut(x, y)) //如果没有被访问且没有出界 则访问 { cal++; chress[x][y] = cal; //做标记 dfs(x + 2, y + 1); //骑士走法有八个方位,故八个 方位都遍历 dfs(x - 2, y - 1); //八个递归的顺序可以改,顺序不一样,结果不一样 dfs(x + 2, y - 1); dfs(x - 2, y + 1); dfs(x - 1, y - 2); dfs(x + 1, y - 2); dfs(x + 1, y + 2); dfs(x - 1, y + 2); return; } else //出界了则退出return return;}int main(){ int x, y; cout << "请输入骑士初始的位置:"; while (1) { cin >> x >> y; //输入坐标 if (x > 7 || x<0 || y> 7 || y < 0) cout << "初始位置输入错误请重新输入" << endl; else break; } dfs(x,y); for (int i = 0; i < 8; i++) //输出打印测试 { for (int j = 0; j < 8; j++) cout << setw(2)< ⑥测试截图:
感谢你能够认真阅读完这篇文章,希望小编分享的"C++骑士游历问题的示例分析"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!
象棋
骑士
国际
国际象棋
顺序
中国象棋
方位
标记
走法
中国
问题
格子
棋盘
篇文章
递归
输入
示例
C++
分析
个位
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
金融机构网络安全联席会议
软件开发设计费报价
寻宝天行网络技术
平谷区信息网络技术
数据库 关系
数据库如何快速检索
软件开发与管理就业前景
江苏开放大学数据库系统原理
永久60怎么去人多的服务器
网络安全管理员补贴
diabetes 数据库
企业社交网络安全工程师
传奇私服数据库文件
广东标准软件开发定制价格
远程服务器 iis
软件开发最多的计算机语言
安卓手机数据库使用方法
网络安全项目管理及保密制度
博山资产软件开发服务
服务器的配制与管理
数据库表什么时候建立索引
用centos安装数据库
双十一网络安全保障
田径网络技术有限公司
深圳市海跃网络技术
自研数据库服务
葫芦娃手游服务器
通州区信息网络技术推广系统
甘肃通用网络技术有限公司
明日之后服务器闪退怎么办