魔方求解器程序(层先法,java版本)
实现了一个三阶魔方的层先法求解程序: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版本)的更多相关文章
- 【转载】自动化魔方求解器的Bug——选择合适的色彩空间
目录 1. 准备工作-- 2. RGB颜色空间 3. LAB色彩空间 4. YCrCb色彩空间 5. HSV色彩空间 Color spaces in OpenCV (C++ / Python) 几天前 ...
- atitit.添加win 系统服务 bat批处理程序服务的法总结instsrv srvany java linux
atitit.添加win 系统服务 bat批处理程序服务的法总结instsrv srvany java linux 系统服务不同于普通视窗系统应用程式.不可能简简单单地通过运行一个EXE就启动视窗系 ...
- atitit.加入win 系统服务 bat批处理程序服务的法总结instsrv srvany java linux
atitit.加入win 系统服务 bat批处理程序服务的法总结instsrv srvany java linux 系统服务不同于普通视窗系统应用程式.不可能简简单单地通过执行一个EXE就启动视窗系 ...
- PCB仿真软件与电磁场求解器的算法
1. 简介 目前商业化的PCB仿真软件主要有: Cadence公司的Sigrity.Ansys公司的SIwave/HFSS.CST公司的CST.Mentor公司的HyperLynx.Polor公司的S ...
- 编程之美之数独求解器的C++实现方法
编程之美的第一章的第15节.讲的是构造数独.一開始拿到这个问题的确没有思路, 只是看了书中的介绍之后, 发现原来这个的求解思路和N皇后问题是一致的. 可是不知道为啥,反正一開始确实没有想到这个回溯法. ...
- 【转载】国外程序员整理的Java资源大全
以下转载自: 推荐!国外程序员整理的Java资源大全中文版 https://github.com/akullpp/awesome-java英文版 Java 几乎是许多程序员们的入门语言,并且也是 ...
- SCIP | 数学规划求解器SCIP超详细的使用教程
前言 小伙伴们大家好呀!继上次lp_solve规划求解器的推文出来以后,大家都期待着更多求解器的具体介绍和用法.小编哪敢偷懒,这不,赶在考试周之际,又在忙里偷闲中给大家送上一篇SCIP规划求解的推文教 ...
- 数学规划求解器lp_solve超详细教程
前言 最近小编学了运筹学中的单纯形法.于是,很快便按奈不住跳动的心.这不得不让我拿起纸和笔思考着,一个至关重要的问题:如何用单纯形法装一个完备的13? 恰巧,在我坐在图书馆陷入沉思的时候,一位漂亮的小 ...
- 你的程序支持复杂的时间调度嘛?如约而来的 java 版本
你的程序支持复杂的时间调度嘛? 这篇文章介绍了时间适配器的c#版本,是给客户端用的,服务器自然也要有一套对应的做法,java版本的 [年][月][日][星期][时间] [*][*][*][*][*] ...
- TRAC-IK机器人运动学求解器
TRAC-IK和Orocos KDL类似,也是一种基于数值解的机器人运动学求解器,但是在算法层面上进行了很多改进(Specifically, KDL’s convergence algorithms ...
随机推荐
- java正则表达式(find()和 matches())
1.find()方法是部分匹配,是查找输入串中与模式匹配的子串,如果该匹配的串有组还可以使用group()函数. matches()是全部匹配,是将整个输入串与模式匹配,如果要验证一个输入的数据是否为 ...
- Qt编写的项目作品25-硬件综合应用(热敏打印+身份证+短信猫)
一.功能特点 (一).串口热敏打印 标准热敏打印协议解析,无依赖,支持任意系统. 可打印各种文字信息比如访客单.报警信息等. 可打印条形码即一维码. 可打印二维码,设置二维码尺寸. 支持多线程打印图片 ...
- UML之包的导入与访问
包是UML中管理元素的有效手段,UML中的所有元素均隶属于某一个包,即使你没有指定元素所属的包,这些元素也会被置于一个默认包中,包的本质是命名空间.当我们在一个包中需要访问另一个包中的元素时,可以使用 ...
- B站千万级长连接实时消息系统的架构设计与实践
本文由哔哩哔哩资深开发工程师黄山成分享,原题"千万长连消息系统",本文进行了排版和内容优化等. 1.引言 在当今数字娱乐时代,弹幕已经成为直播平台上不可或缺的互动元素之一. 用户通 ...
- Windows安全加固(二)
三.本地安全策略用户权限分配 1. 使用windows+R打开运行,输入"secpol.msc"打开本地安全策略->本地策略->用户权限分配->找到"拒 ...
- keycloak~巧用client-scope实现token字段和userinfo接口的授权
keycloak中的client-scope允许你为每个客户端分配scope,而scope就是授权范围,它直接影响了token中的内容,及userinfo端点可以获取到的用户信息,这块我们可以通过自定 ...
- WPF 获取拖拽网页图片链接
在浏览器里拖拽一个元素,我只获取图片链接 private void Grid_PreviewDragOver(object sender, DragEventArgs e) { e.Effects = ...
- 配置教程-jdk-tomcat-maven
二.下载并安装JDK 选择一个适合自己的JDK版本下载并安装即可,具体流程不详述. 二.环境变量配置 1.右键桌面上"我的电脑">>"属性",在弹出 ...
- TCP/IP协议笔记
TCP/IP 一.TCP/IP简介 TCP/IP 指传输控制协议/网际协议(Transmission Control Protocol / Internet Protocol),是用于因特网 (Int ...
- 玩转云端|天翼云边缘安全加速平台AccessOne实用窍门之保障热门产品发售服务安全稳定
本文分享自天翼云开发者社区<玩转云端|天翼云边缘安全加速平台AccessOne实用窍门之保障热门产品发售服务安全稳定>,作者:天翼云社区官方账号 随着社会经济的发展和人民生活水平的提高,越 ...