实现了一个三阶魔方的层先法求解程序:https://github.com/davelet/java-puzzle-resolver

欢迎试用。


用法

1. 随机试用

不关注起始状态的话可以用程序的随机拧乱工具打乱然后复原:

    private Cube cube;

    private CubeSolver cubeSolver;
private CubeShuffler cubeShuffler; @BeforeEach
void setUp() {
cube = new Cube();
cubeSolver = new CubeSolver(cube);
cubeShuffler = new CubeShuffler(cube);
} @Test
void solve_ExecuteBottomCornerSolver() {
// 打乱魔方,随机拧20次
cubeShuffler.shuffle(20);
// 执行测试
cubeSolver.solve();
// 验证结果
assertTrue(cube.isSolved());
}

2. 特定状态的求解

要把状态初始化成某个特定状态,可以使用Cube的构造器:

public class Cube implements Cloneable {
private final Color[][][] state; public Cube() {
state = new Color[6][SIZE][SIZE];
initializeCube();
} // 使用这个方法传入一个三维数组
public Cube(Color[][][] state) {
this.state = state;
if (!isValid()) {
throw new IllegalArgumentException("提供的状态不是有效的魔方状态");
}
}
// ...其他代码 }

状态是一个三维数组,维度分别是某个面、某一行、某一列。所以面做多6个(0~5),行和列做多3个。

数组的元素是 Color 枚举对象:

public enum Color {
WHITE("白", "\u001B[37m"),
YELLOW("黄", "\u001B[33m"),
RED("红", "\u001B[31m"),
ORANGE("橙", "\u001B[38;5;208m"),
BLUE("蓝", "\u001B[34m"),
GREEN("绿", "\u001B[32m");
// ...
}

特别要注意的是,这里要求市场标准魔方且不能转动魔方的方向

也就是说,魔方的六个面必需遵守 上黄下白前蓝后绿左橙右红 的布局;这样就要求状态数组中每个面的中心块 (state[face][1][1])对应是面的颜色。

求解

层先法的逻辑毕竟简单清晰。但是我实现过程中也查了非常多资料,因为不同博客对层先法的过程说得不一样,尤其是顶层还原的时候。

而且我要实现的是求解过程不转动魔方方向,只拧某一层。很多资料都让上下颠倒魔方,或者找一个目标块放到左(右)手边。

求解过程每次拧动魔方(执行一套公式,里面会包含拧动好几次),都会打印日志:



日志中的魔方是按照“上面、后面的镜像、左面、前面、右面、下面”顺序摆放的。

如果某个块的颜色和当前面的颜色一样了,就用圆圈表示。

代码结构

魔方求解器程序(层先法,java版本)的更多相关文章

  1. 【转载】自动化魔方求解器的Bug——选择合适的色彩空间

    目录 1. 准备工作-- 2. RGB颜色空间 3. LAB色彩空间 4. YCrCb色彩空间 5. HSV色彩空间 Color spaces in OpenCV (C++ / Python) 几天前 ...

  2. atitit.添加win 系统服务 bat批处理程序服务的法总结instsrv srvany java linux

    atitit.添加win 系统服务 bat批处理程序服务的法总结instsrv srvany  java linux 系统服务不同于普通视窗系统应用程式.不可能简简单单地通过运行一个EXE就启动视窗系 ...

  3. atitit.加入win 系统服务 bat批处理程序服务的法总结instsrv srvany java linux

    atitit.加入win 系统服务 bat批处理程序服务的法总结instsrv srvany  java linux 系统服务不同于普通视窗系统应用程式.不可能简简单单地通过执行一个EXE就启动视窗系 ...

  4. PCB仿真软件与电磁场求解器的算法

    1. 简介 目前商业化的PCB仿真软件主要有: Cadence公司的Sigrity.Ansys公司的SIwave/HFSS.CST公司的CST.Mentor公司的HyperLynx.Polor公司的S ...

  5. 编程之美之数独求解器的C++实现方法

    编程之美的第一章的第15节.讲的是构造数独.一開始拿到这个问题的确没有思路, 只是看了书中的介绍之后, 发现原来这个的求解思路和N皇后问题是一致的. 可是不知道为啥,反正一開始确实没有想到这个回溯法. ...

  6. 【转载】国外程序员整理的Java资源大全

    以下转载自: 推荐!国外程序员整理的Java资源大全中文版    https://github.com/akullpp/awesome-java英文版 Java 几乎是许多程序员们的入门语言,并且也是 ...

  7. SCIP | 数学规划求解器SCIP超详细的使用教程

    前言 小伙伴们大家好呀!继上次lp_solve规划求解器的推文出来以后,大家都期待着更多求解器的具体介绍和用法.小编哪敢偷懒,这不,赶在考试周之际,又在忙里偷闲中给大家送上一篇SCIP规划求解的推文教 ...

  8. 数学规划求解器lp_solve超详细教程

    前言 最近小编学了运筹学中的单纯形法.于是,很快便按奈不住跳动的心.这不得不让我拿起纸和笔思考着,一个至关重要的问题:如何用单纯形法装一个完备的13? 恰巧,在我坐在图书馆陷入沉思的时候,一位漂亮的小 ...

  9. 你的程序支持复杂的时间调度嘛?如约而来的 java 版本

    你的程序支持复杂的时间调度嘛? 这篇文章介绍了时间适配器的c#版本,是给客户端用的,服务器自然也要有一套对应的做法,java版本的 [年][月][日][星期][时间] [*][*][*][*][*] ...

  10. TRAC-IK机器人运动学求解器

    TRAC-IK和Orocos KDL类似,也是一种基于数值解的机器人运动学求解器,但是在算法层面上进行了很多改进(Specifically, KDL’s convergence algorithms ...

随机推荐

  1. 【网络安全】Shell 脚本学习

    声明:学习视频来自 b 站 up 主 泷羽 sec,如涉及侵权马上删除文章 声明:本文主要用作技术分享,所有内容仅供参考.任何使用或依赖于本文信息所造成的法律后果均与本人无关.请读者自行判断风险,并遵 ...

  2. UML之图框架标题类型之谬

    在UML中,我们可以用一个被称为"框架"的边界框围绕着UML图形,当然在很多情况下,框架可以省略,也就是不将它描画出来.但是对于某些图形类型而言,框架具有语义意义,在这些图形类型中 ...

  3. VC++2008、2010、2012、2015、2017等IDE中如何设置命令行参数进行程序调试

    有时我们在写程序时会从命令行中直接读入参数,形如: int main(int argc,char**argv){ //your code here return 0; } 其实在vc2010 IDE中 ...

  4. [转]vue-router动态添加路由的方法,addRouter添加路由,提示:Duplicate named routes definition

    问题描述:在做使用vue-router动态添加路由的方法,addRouter添加,使用 console.log(this.$router.options.routes) 打印对象,发现添加成功,但是一 ...

  5. 再制作个WCH-LINK下载器

    用CH549可以制作成支持两种模式的WCH-LINK下载器,两种模式指的是RISC-V和DAPLINK模式. 如果用于沁恒的CH32V203等芯片,我们可以将这个下载器设置成RISC-V下载模式. 如 ...

  6. 异步 QQ 机器人框架_NoneBot

    一.NoneBot使用 1) #监控发送的消息"群发"的事件@on_command('send_msg', aliases=('群发',))async def send_msg(s ...

  7. 深入LinkedBlockingQueue实现原理

    学习BlockingQueue之LinkedBlockingQueue实现原理   一:概念 LinkedBlockingQueue是一个用链表实现的有界阻塞队列.此队列的默认和最大长度为 Integ ...

  8. k8s~控制deamonset中pod的数量

    DaemonSet 是 Kubernetes 中的一种控制器,用于确保集群中的每个节点(或特定标签选择器匹配的节点)运行一个 Pod 的副本.DaemonSet 通常用于运行集群守护进程,如日志收集. ...

  9. 如何使用C++ STL中的链表list

    1.声明链表 list<数据类型> 链表名称: 比如: list<int> listName;  //创建一个空链表listName list<int> listN ...

  10. 快速入门 DeepSeek-R1 大模型

    国内最新的神级人工智能模型已经正式发布,没错,它就是备受瞩目的DeepSeek-R1大模型.今天,我们将对DeepSeek进行一个简单的了解,并探索如何快速使用和部署这个强大的工具.值得一提的是,De ...