0%
这是一片思考的空间 -- arthinking
Spring 重构&代码整洁之道 软件设计 JVM 并发编程 数据结构与算法 分布式 存储 网络 微服务 设计模式
Java技术栈 - 涉及Java技术体系

碰撞球(连连看)游戏 连连看匹配算法分析与实现思路

前段时间空闲之余制作了一个基于Javascripit和HTML5的canvas面板的碰撞球连连看小游戏,游戏地址:点击IT宅桌面中的碰撞球图标即可。

连连看涉及到的算法也不是很复杂,这里我主要是分为三种情况去分析,下面逐个分析。

首先是初始化连连看数组,把所有的图片看成是一个二维数组,有图片的地方置1,没有图片的地方置0。

1、两个图片相邻的情况:

这种情况下,我们只需要把两个图片的x坐标和y坐标分别相减并取绝对值:

A = | x1 – x2 |; B = | y1 – y2 |;

只要发现计算的A,B两个值中,有一个为0,一个为1,即表示这两个图片是相邻的。

2、两条连线的情况:

20120410-link01

如上图这种情况为图片对角,其中根据对角线的不同又可以分为两种情况,即左上角对右下角和右上角对左下角。其分析思路大致是一样的,只是细节的判断时方向可能不一样,这里我们就选择图中的左上角对右下角这种情况来分析。

1、首先如图所示,我们分别设左上角和右下角为A(x1,y1) B(x2,y2)点,这样我们可以找到其他的两个顶点的坐标C(x1,y2) D(x2,y1)。

2、判断CD两点是否无图片,即值是否为0,如果是则使用该点继续判断,否则放弃该点。如上图则C点无图,符合条件,转入下一步处理。

3、根据上一步获取到的点,判断该点分别与AB两点之间的连线上是否都不存在图片,如果不存在则表示连连看配对成功,否则,配对失败。如上图AC和BC两条连线上均没有图片,符合规则,所有AB两点配对成功。

3、三条连线的情况:

20120410-link02

如上图所示,也可以具体分为两种情况考虑,我们现在先说其中的一种。

设左边的大空翼为A,右边的大空翼为B,我们先分别查找AB两点Y轴方向包括AB两点的最大的连续没有图片的位置,我们找到了如上图所示的左右两个绿色矩形框的位置。

接着在这两个矩形框中查找Y轴方向上的公有部分如图,左右两个矩形框中的白色矩形框即为Y轴上的公有部分。

我们在这个公有部分的Y轴范围分别逐个横着扫描其中的每一条连线,查看是否有其中的一条直线中没有图片,则匹配成功。上图中,我们扫描第一条直线时就发现了一条完整的没有图片的图片,即是图中中间那个绿色矩形框。这样就匹配成功了。

而至于另外一种情况,把上图作90度旋转,作类似的操作即可判断。

欢迎关注我的其它发布渠道

订阅IT宅
内功修炼
Java技术栈
Java架构杂谈是IT宅精品文章公众号,欢迎订阅:
📄 网络基础知识:两万字长文50+张趣图带你领悟网络编程的内功心法 📄 HTTP发展史:三万长文50+趣图带你领悟web编程的内功心法 📄 HTTP/1.1:可扩展,可靠性,请求应答,无状态,明文传输 📄 HTTP/1.1报文详解:Method,URI,URL,消息头,消息体,状态行 📄 HTTP常用请求头大揭秘 📄 HTTPS:网络安全攻坚战 📄 HTTP/2:网络安全传输的快车道 📄 HTTP/3:让传输效率再一次起飞 📄 高性能网络编程:图解Socket核心内幕以及五大IO模型 📄 高性能网络编程:三分钟短文快速了解信号驱动式IO 📄 高性能网络编程:彻底弄懂IO复用 - IO处理杀手锏,带您深入了解select,poll,epoll 📄 高性能网络编程:异步IO:新时代的IO处理利器 📄 高性能网络编程:网络编程范式 - 高性能服务器就这么回事 📄 高性能网络编程:性能追击 - 万字长文30+图揭秘8大主流服务器程序线程模型
📄 Java内存模型:如果有人给你撕逼Java内存模型,就把这些问题甩给他 📄 一文带你彻底理解同步和锁的本质(干货) 📄 AQS与并发包中锁的通用实现 📄 ReentrantLock介绍与使用 📄 ReentrantReadWriteLock介绍与使用 📄 ReentrantLock的Condition原理解析 📄 如何优雅的中断线程 📄 如何优雅的挂起线程 📄 图解几个好玩的并发辅助工具类 📄 图解BlockingQueue阻塞队列
📄 消息队列那么多,为什么建议深入了解下RabbitMQ? 📄 高并发异步解耦利器:RocketMQ究竟强在哪里? 📄 Kafka必知必会18问:30+图带您看透Kafka
📄 洞悉MySQL底层架构:游走在缓冲与磁盘之间 📄 SQL运行内幕:从执行原理看调优的本质 📄 洞悉Redis技术内幕:缓存,数据结构,并发,集群与算法