魔方求解器程序(层先法,java版本)

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

欢迎试用。


用法

1. 随机试用

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

java 复制代码
    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的构造器:

java 复制代码
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 枚举对象:

java 复制代码
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])对应是面的颜色。

求解

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

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

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

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

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

代码结构

相关推荐
雨中飘荡的记忆5 分钟前
LangChain4j 实战指南
java·langchain
okseekw7 分钟前
Java 中的方法:从定义到重载的完整指南
java
雨中飘荡的记忆8 分钟前
深入理解设计模式之适配器模式
java·设计模式
用户84913717547169 分钟前
生产级故障排查实战:从制造 OOM 到 IDEA Profiler 深度破案
java·jvm
雨中飘荡的记忆12 分钟前
深入理解设计模式之装饰者模式
java·设计模式
雨中飘荡的记忆16 分钟前
秒杀系统设计与实现
java·redis·lua
小坏讲微服务41 分钟前
Spring Cloud Alibaba 整合 Scala 教程完整使用
java·开发语言·分布式·spring cloud·sentinel·scala·后端开发
老鼠只爱大米1 小时前
Java设计模式之外观模式(Facade)详解
java·设计模式·外观模式·facade·java设计模式
vx_dmxq2111 小时前
【微信小程序学习交流平台】(免费领源码+演示录像)|可做计算机毕设Java、Python、PHP、小程序APP、C#、爬虫大数据、单片机、文案
java·spring boot·python·mysql·微信小程序·小程序·idea
9号达人1 小时前
优惠系统演进:从"实时结算"到"所见即所得",前端传参真的鸡肋吗?
java·后端·面试