华容道问题求解_详细设计(四)之查找算法2_BFS

(续上篇)
利用BFS查找,会找到最短路径(没有权重的图),这个道理比较简单,这是由于寻找路径的方法都是从起点或者接近起点的位置开始的。查找过程如果画出图来,类似于一圈圈的放大,你可以想想是一个类似圆的渐开线的扫描过程。
前文已经谈到,这个BFS和DFS的主要不同就是对当前参数的保存方法不同,即BFS采用队列保存,DFS采用堆栈保存。因此,将DFS的保存当前参数的方法改成队列就可以实现BFS了。

BFS 核心代码

       internal bool SearchPathBFS(int endHashCode){if (statesObjQueue.Count == 0) return false;//##############################################################//## BFS 代码的改变如下                                        ##//##############################################################var lastState = DequeueState(); //var lastHashCode=   layoutHashCodeStk.Pop();// map it to the current  state MapToCurState(lastState);var curBestSteps = lastState.bestSteps+1;while (gameState.openPieces.Count > 0 && gameState.curOpenIdx < gameState.openPieces.Count)// There are open pieces not moved , move them one by one.{var selOpenPcs = gameState.openPieces[gameState.curOpenIdx];var selPcs = selOpenPcs.piece;var toPcs = selOpenPcs.MoveToPcs;var dirFrom = MoveToPcs(selPcs, toPcs);gameState.selPcs = selPcs;var redundant = RedundantState(gameState);StateShot stateShot = new StateShot(gameState, 0);// record the current best steps stateShot.bestSteps = curBestSteps;//Create the graph data structure AddEdgeToGraph(lastState, stateShot);if (gameState.curOpenIdx < lastState.openPcsArr.Length){gameState.curOpenIdx++;lastState.lastOpenIdx = gameState.curOpenIdx;}if (!redundant.Item1){SearchOpenPieces();stateShot = new StateShot(gameState, 0);stateShot.bestSteps = curBestSteps;//##############################################################//## BFS 代码的改变如下                                       ##//##############################################################         EnqueueState(lastState, stateShot, selPcs, toPcs);//add edge to the grapph and enqueue the current state}// 2024-01-30 Found the least steps with BFS and it runs very fast.// Judge if it succeeds that caocao is at the exit of the board.if (endHashCode==0 && selPcs.type == 4){if (selPcs.hrdPos.X == 2 && selPcs.hrdPos.Y == 4){RefreshLayout();Application.DoEvents();var verTex = GetMyHashCodeV1(gameState);// the layout might not the same that needs to record all of them if (!endVtxLst.Contains(verTex)) endVtxLst.Add(verTex);//MessageBox.Show(string.Format("Success! The best steps is {0},the hash code is {1}", hCodeAndShotShortPathDict[verTex].Item2, verTex));//return false;//debug}}else if (redundant.Item2 == endHashCode){RefreshLayout();Application.DoEvents();var verTex = GetMyHashCodeV1(gameState);// the layout might not the same that needs to record all of them if (!endVtxLst.Contains(verTex)) endVtxLst.Add(verTex);}MapToCurState(lastState); // back the last state and try to moev next open pieces}return true;}

和DFS的代码对比一下就会发现,除了堆栈改成队列之外,代码几乎没有做什么改变。

下面给出 两个主要变化的函数代码
入队代码:

       private void EnqueueState(StateShot source, StateShot dest, Piece selPcs, Piece dstPcs){statesObjQueue.Enqueue(dest);var toHashCode = GetMyHashCode(dest);stateHashCodeLst.Add(toHashCode);int[,] layoutArr = new int[6, 7];Array.Copy(dest.layoutOfIdx, layoutArr, layoutArr.Length);hCodeAndShotDict.Add(toHashCode, (dest.basePcs, selPcs.idx, dstPcs.idx));var frmHashCode = GetMyHashCode(source);AddEdge(frmHashCode, toHashCode, 1);}

出队代码

       private StateShot DequeueState(){var stshot = statesObjQueue.Dequeue();//stateHashCodeStack.Pop();return stshot;}

其中 statesObjQueue 的定义为;

//used to store the game state and the shortest path from last state For BFS search private Queue<StateShot> statesObjQueue= new Queue<StateShot>();

运行之后,就很快找到了最少步数,虽然在过程当中也构建了一个图,但是并没有使用这个图。

结果也比较理想,是一个对称的结果,符合预期。这个原因,我想是因为在BFS 的求解过程当中的每一次探索的步数的基数都是一样的,而路径是不同的,因此也就必然会出现这么一种结果。
运行结果获得30种符合要求的布局,根据对称性,应该是15 中不同的解法。
截图如下:
说明:左面列表数值是该布局对应的Hash值
在这里插入图片描述
在这里插入图片描述
对比上面的布局,发现这是个对称的布局。这些解法中,最少的是81步,最多的是 115步。
其余结果请参考下列视频。另外 “不同解法 ”的含义就是最终的布局不同。

横刀立马最佳结果集


基本功能的探索到此告一段落,后面将对显示和布局设计进行一些尝试。

marasun BJFWDQ
204-03-09

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/733435.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【动态规划入门】判断子序列

每日一道算法题之判断子序列 一、题目描述二、思路三、C代码 一、题目描述 题目来源&#xff1a;LeetCode 给定字符串 s 和 t &#xff0c;判断 s 是否为 t 的子序列。 字符串的一个子序列是原始字符串删除一些&#xff08;也可以不删除&#xff09;字符而不改变剩余字符相对位…

HashMap 底层,同时遍历+删除会出现什么问题?怎么解决

HashMap底层使用的是数组链表/红黑树的方式实现的 在并发场景下同时进行遍历删除&#xff0c;会出现ConcurrentModificationException异常&#xff0c;这是因为HashMap的迭代器是快速失败的&#xff08;fail-fast&#xff09;,当检测到结构性的改变&#xff08;比如增加或删除…

java IO实现一次性读取一个文件全部内容后在写入一个文件

java IO实现一次性读取一个文件全部内容后在写入一个文件 import java.io.*;/*** author admin*/ public class FileIo {public static void main(String[] args) {String content getFileString();File outputFile new File("C:\\Users\\admin\\Desktop\\test\\1.txt&…

Kubernetes 几大概念的作用

更详细的组件通信流程 Kubernetes 主要由以下几个核心组件组成&#xff1a; 1. etcd 保存了整个集群的状态&#xff1b; 2. API Server 提供了资源操作的唯一入口&#xff0c;并提供认证&#xff0c;授权&#xff0c;访问控制&#xff0c;API 注册和发现等机制&#xff1b; …

python安装graph-tool 和 torch_geometric,pytorch总结:

目录 1.graph-tool 2.torch_geometric 3.pytorch 1.graph-tool &#xff08;1&#xff09;各种方式试过了&#xff0c;本地安装的没法正常用&#xff1a;conda本地化安装&#xff08;conda install --use-local&#xff09;&#xff0c;以 graph-tool 安装为例 - 知乎 &…

Leetcode每日一题】 二维前缀和 - 矩阵区域和(难度⭐⭐)(31)

1. 题目解析 题目链接&#xff1a;1314. 矩阵区域和 题目乍一看很晦涩难懂&#xff0c;又是大于等于又是k的 仔细分析&#xff0c;题目所说的意思就是以[i,j]为中心&#xff0c;求上下左右向外拓展k个单位的矩阵和&#xff0c;放在名为answer的矩阵中&#xff0c;最后返回ans…

Java里的泛型<T> T 的运用

因为我总是写一些CRUD的代码&#xff0c;泛型的知识都忘得差不多了&#xff0c;今天特地来写一下。 泛型可以认为是 把类型参数化&#xff0c;方便代码重用。 Double[] num new Double [] {1.11, 2.22}; String[] str new String [] {"hello", "world"…

Session登陆实践

Session登陆实践 Session登录是一种常见的Web应用程序身份验证和状态管理机制。当用户成功登录到应用程序时&#xff0c;服务器会为其创建一个会话&#xff08;session&#xff09;&#xff0c;并在会话中存储有关用户的信息。这样&#xff0c;用户在与应用程序交互的整个会话…

设计模式 代理模式

代理模式主要使用了 Java 的多态&#xff0c;主要是接口 干活的是被代理类&#xff0c;代理类主要是接活&#xff0c; 你让我干活&#xff0c;好&#xff0c;我交给幕后的类去干&#xff0c;你满意就成&#xff0c;那怎么知道被代理类能不能干呢&#xff1f; 同根就成&#xff…

leetcode 估算题

2117. 一个区间内所有数乘积的缩写 class Solution {public String abbreviateProduct(int left, int right) {long c 0, suf 1, maxSuf (long) 1e11, len 0;double pre 1.0;for (int num left; num < right; num) {pre * num;suf * num;while (pre > 100000) { /…

档案室管理人员有哪些岗位

档案室管理人员的岗位可以分为以下几类&#xff1a; 1. 档案文书管理岗位&#xff1a;负责档案文书的管理、整理、归档和借阅工作&#xff0c;包括档案资料的分类、编目、装订、存储等。 2. 档案数字化管理岗位&#xff1a;负责将纸质档案数字化&#xff0c;进行扫描、转换、存…

你喜欢那种舞者呢?

迷宫中的舞者&#xff1a;程序员职业赛道的探索与魅力 在数字世界的深处&#xff0c;程序员的职业赛道宛如一座神秘而迷人的迷宫。这个迷宫中&#xff0c;每个转角都隐藏着无限的可能&#xff0c;每个领域都散发着独特的魅力。前端开发者如同花园中的精灵&#xff0c;后端工程师…

mac下终端命令提示补全

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 mac下终端命令提示补全 前言Zsh-autosuggestions原理解析&#xff1a;智能提示的工作方式1. 命令历史分析&#xff1a;2. 智能提示生成&#xff1a;3. 用户交互和选择&#xff1a;4. 配置和个性化&…

Linux基础IO【 详 解 】

文章目录 C语言文件IOC语言文件接口汇总默认打开的三个流 系统文件IOopenclosewriteread 文件描述符fd文件描述符的分配规则重定向重定向的本质dup2 FILEFILE当中的文件描述符FILE当中的缓冲区 理解文件系统初识inode磁盘分区与格式化介绍 软硬链接软链接硬链接软硬链接的区别 …

CorelDRAW Graphics Suite2024专业图形设计软件Windows/Mac最新25.0.0.230版

CorelDRAW Graphics Suite 2024是一款专业的图形设计软件&#xff0c;它集成了CorelDRAW Standard 2024和其他高级图形处理工具&#xff0c;为用户提供了全面的图形设计和编辑解决方案。 该软件拥有强大的矢量编辑功能&#xff0c;用户可以轻松创建和编辑矢量图形&#xff0c;…

UI 易用性测试 以及自动化实现!

GUI 是指图形用户界面&#xff0c;UI 是指用户界面&#xff0c;对于纯软件系统&#xff0c;这两者没有本质的区别&#xff0c;GUI易用性测试与 UI 易用性测试内容一致。但是如果测试的对象是一个产品&#xff0c;这两者则存在区别&#xff0c;对于产品 UI 则不仅仅包括 GUI&…

多线程-线程池原子性并发工具类

1.线程池 1.线程状态 虚拟机中线程的六种状态 新建状态&#xff08;NEW&#xff09; --创建线程 就绪状态&#xff08;RUNNABLE&#xff09; --start方法 阻塞状态&#xff08;BLOCKED&#xff09; --无法获得锁对象 等待状态&#xff08;WAITING&#xff09; …

springboot254小区团购管理

小区团购管理设计与实现 摘 要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装小区团购管理软件来发挥其高效地信…

菜鸟笔记-14Python绘图颜色使用

Python中绘图主要依赖于各种库&#xff0c;其中matplotlib是最常用且功能强大的一个。在matplotlib中&#xff0c;你可以使用各种颜色来表示不同的数据点、线条或填充区域。下面我将详细介绍如何在Python中使用matplotlib来设置绘图颜色&#xff0c;并给出具体的例子。 14.1颜…

Spring循环依赖问题分析

对象分类&#xff1a;1.成品对象&#xff1a;实例化完成 初始化完成 2.半成品对象&#xff1a; 实例化完成 初始化未完成 实例化和初始化可以分开执行是解决循环依赖问题的关键 一级缓存&#xff1a;保存完成的bean对象 二级缓存&#xff1a;存储成品对象 三级缓存&#xff1a…