马踏棋盘MFC教程

时间:2024-10-29 09:11:28

1、马踏棋盘经典算法描述:马踏棋盘是经典的程序设计问题之一,主要的解决方案有两种:一种是基于深度优先搜索的方法,另一种是基于贪婪算法的方法。第一种基于深度优先搜索的方法是比较常用的算法。

马踏棋盘MFC教程

2、深度优先搜索算法也是数据结构中的经典算法之一,主要是采用递归的思想,一级一级的寻找,遍历出所有的结果,最后找到合适的解。

马踏棋盘MFC教程

3、而基于贪婪的算法则是制定贪心准则,一旦设定不能修改,他只关心局部最优解,但不一定能得到最优解。

马踏棋盘MFC教程

4、关于马踏棋盘的基本过程:国际象棋的棋盘为 8*8 的方格棋盘。现将"马"放在任意指定的方格中,按照"马"走棋的规则将"马"进行移动。要求每个方格只能进入一次,最终使得"马"走遍棋盘的64个方格。

马踏棋盘MFC教程
马踏棋盘MFC教程

5、【算法分析】在四角,马踏日走只有两个选择;在其余部分,马踏日走有四、六、八不等的选择。

马踏棋盘MFC教程

6、解决方案:在外层另外加上两层,确保 8*8 方格中的每一个格子都有8中不同的选择;重点:为了确保每个格子能走日字,而且选择的可能性等同,初始化除了最外两层格子标记没有被访问,最外两层中每个格子都标记为已被访问即可达到目标!

马踏棋盘MFC教程
© 手抄报圈