三消游戏查找算法的原理和实现

news2025/1/16 5:10:09
本文首发于公众号: 小蚂蚁教你做游戏。欢迎关注领取更多学习做游戏的原创教程资料,每天学点儿游戏开发知识。

嗨!大家好,我是小蚂蚁。

今天这篇文章分享一下三消查找算法的原理和实现,其实三消的机制最早源于《宝石方块》这款经典游戏,如今三消已经属于一个游戏品类了。

最近刚好正在制作一款宝石方块游戏,顺便讲一下其中的三消查找算法。一直以为之前写过了,找了一圈发现并没有,今天就在这里补上。

三消的查找算法都是通用的,可以用于几乎所有的三消游戏,如果你之前不知道的话,那么今天的这篇教程就可以好好的研究研究了。

三消查找的原理

如图,是一个典型的消除游戏的画面。这里一共有 4 种不同的宝石,图中第一行的前三个红色宝石是相邻的,满足三消的条件(相邻的 3 个宝石相同,就可以消除)。

这是我们直观看到的画面,以及通过这个画面做出的判断。但是对于计算机来讲,它看不到我们所看到的这些不同的形状和颜色宝石,它能看到的是数据。

想要用计算机编写程序实现查找算法,首先要将我们所看到的这些东西转化成计算机能够理解的数据。

如图,为四个宝石分配 1,2,3,4 的四个数字,然后把这些数字填写到右侧对应的格子中,没有宝石的格子用 0 填充。

这样,我们就得到了一个计算机能看懂,而且也很擅长处理的数据表格。这个数据表格是三消查找算法的基础,后续的所有查找操作都基于这个数据表格。其实右侧的数据表格完全等同于左侧的这个由不同颜色宝石填充的表格。

第一轮检查

有了数据表格之后,就能够进行查找操作了。这里我先描述一下查找的过程:从第一个宝石开始,依次检查它的左、上、右、下,四个相邻位置的宝石,如果发现相邻位置的宝石跟自己相同,那么就记下这个宝石的位置,并且从这个宝石的位置开始,继续向同一方向检查,直到相邻位置的宝石不相同为止。如果相邻位置的宝石跟自己不同就继续检查下一个相邻位置,直到检查完所有的四个相邻位置。

看不懂是吧?没关系。先看个大概,然后接着看下面的图片。

上方是左下角第一个红色宝石的查找过程,结合着整个流程图,再去理解一下之前说的查找过程。

当然,这只是第一个方块的查找,在整个游戏中,每个格子中的宝石都需要进行这样的检查过程。是不是觉得很多?计算机可是一点儿都不会这么觉得,因为检查计算就是它所擅长的事。

这样检查一下就完事了吗?当然不是了。

通过第一轮检查,我们找到了上方的这 4 个宝石,但是这四个宝石并不都满足消除条件,只有在同一行或者同一列上相邻的三个才满足消除条件,所以,只有第一行的三个宝石能够消除,第二行的第一个宝石不能够消除。

第二轮检查

接下来我们就要进行第二轮检查了。在第一轮检查中找到了所有(水平/竖直)相邻的方块,第二轮检查要做的就是,找出其中位于同一行或者同一列的宝石,然后判断在同一行或者同一列上是否有三个或者三个以上的宝石,有的话,这些宝石才是最终要消除的宝石。

在第一轮的查找过程中,我们说找到相同的宝石就记录下来,这里记录的信息是这个宝石在表格中的位置,这个位置可以用一个行号和一个列号来表示。如图,四个宝石的行列号位置分别为 (1,1),(1,2)(1,3),(2,1),第二轮检查就是以这四组数据为基础的。

检查的过程是这样的:拿出第一个位置数据,分别以这个位置数据的行号和列号为准,检查剩余数据的行号或者列号是否与它相等,相等的话就记录下来。待检查完毕后,统计一下位于同一行或者同一列的宝石数量,如果大于等于三个,就将这些宝石的数据记录下来,用于后续的消除处理。

这样,在进行第二轮检查之后,就能够找到最终符合消除条件的宝石了。

以上,就是三消查找算法的原理了。

三消查找的实现

对于第一轮查找来讲,其中的一个难点就是“递归”。这里的查找算法使用了“递归”,即在当前方向上找到相同的宝石后,会继续向前找,直到不相同为止。实现这个不断向前的查找过程,最好的方式就是使用“递归算法”。

第一轮查找放在“水平竖直查找”函数中。

接着来看一下用于递归查找的函数。

“递归查找1”和“递归查找2” 其实是两个相同的函数,它们通过互相调用,以此来实现递归查找。

微信小游戏制作工具并不支持递归函数,但是却留下了一个可爱的小 bug (不知道是不是有意为之),让我们可以使用两个函数互相调用的方式,最终实现递归函数的效果。

在完成了第一轮查找后,我们把所有相同的宝石都放进了“匹配元素的索引”这个列表中了,接下来看一下第二轮查找过程。

在第二轮查找中,我们没有直接使用行列号,而是使用了一个索引,通过索引换算成行列号,然后进行比对,关于索引和行列号的换算,可参见下图。

这些积木看上去很多,实则就是实现了上方原理中讲到的两个查找过程。

理解原理很重要,如果你能够在脑袋中将整个查找过程推演出来,那么实现它只不过是将一个清晰明确的想法表达出来而已。至于使用什么游戏开发工具,是使用积木还是使用代码编写逻辑,那都是实现表达过程而已。如果连想法都没有的话,那么再好的工具,再厉害的语言也都无济于事。

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

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

相关文章

无联不成春,2023创宇网安春联展!

春 联 又叫“春贴”“门对”“对联” 它以对仗工整、简洁精巧的文字 描绘美好形象,寄托美好愿望 是中国独特的文学形式 网络安全的列车已驶入2023,癸卯兔年新春将至! 热爱中华优秀传统文化的创宇人,也纷纷以春联为载体&…

大网进阶安全刷题讲解(带答案)(1)

作者简介:一名云计算网络运维人员、每天分享网络与运维的技术与干货。 座右铭:低头赶路,敬事如仪 个人主页:网络豆的主页​​​​​​ 目录 前言 一.大网进阶安全刷题 前言 本章将会讲解大网进阶安全刷题讲解。 一.大网进阶…

测试开发 | AppCrawler 自动遍历测试实践(二):定制化配置

本文为霍格沃兹测试学院学院学员课程 AppCrawler 学习笔记,文末加群一起学习交流。 定制化配置 自动遍历测试技术以及工具该如何选择和快速入门?经过对比和需求,最终选择测试架构师思寒大佬的 AppCrawler 作为自动遍历测试的工具。以下就分享…

LeetCode 112. 路径总和

🌈🌈😄😄 欢迎来到茶色岛独家岛屿,本期将为大家揭晓LeetCode 112. 路径总和,做好准备了么,那么开始吧。 🌲🌲🐴🐴 一、题目名称 LeetCode 112…

Cadence PCB仿真使用Allegro PCB SI按照指定的规则自动创建差分对方法图文教程

⏪《上一篇》   🏡《总目录》   ⏩《下一篇》 目录 1,概述2,配置方法3,总结1,概述 本文简单介绍使用Allegro PCB SI按照指定的规则自动创建差分的方法。 2,配置方法 第1步:打开待仿真的PCB文件,并确认软件为Allegro PCB SI 如果,打开软件不是Allegro PCB SI则可…

在使用示波器时,为什么有些波形感觉一直在晃?

我们可以从三个角度进行分析: 采样分析: 1、示波器采样信号的过程如上图:采样——处理——采样——处理。 2、处理时间也称死区时间,死区时间内示波器不监测输入信号。 3、提高波形刷新率,实质上是减少了死区时间&…

MyBatis-Plus数据安全保护(配置安全)

SpringBootMyBatis-Plus配置安全 1.该功能为了保护数据库配置及数据安全,在一定的程度上控制开发人员流动导致敏感信息泄露2.加密配置 mpw: 开头紧接加密内容( 非数据库配置专用 YML 中其它配置也是可以使用的 )3.随机密钥请负责人妥善保管&a…

设计模式_创建型模式 -《原型模式》

设计模式_创建型模式 -《原型模式》 笔记整理自 黑马程序员Java设计模式详解, 23种Java设计模式(图解框架源码分析实战) 概述 原型模式 (Prototype Pattern) :用一个已经创建的实例作为原型,通过复制该原型对象来创建…

Kafka的相关知识

一. Kafka基本介绍 Kafka是一个分布式、支持分区的(partition)、多副本的(replica),基于zookeeper协调的分布式消息系统。具有:高吞吐量、低延迟、可扩展性、持久性、可靠性、容错性、高并发等特性。常见的…

RabbitMQ(五)常见面试题

目录1. 什么是 RabbitMQ?2.为什么要使用 RabbitMQ?3.使用 RabbitMQ 的场景4.如何确保消息正确地发送至 RabbitMQ?如何确保消息接收方消费了消息?5.如何避免消息重复投递或重复消费?6.消息基于什么传输?7.消…

基于java ssm springboot网上蛋糕商城项目设计和实现

基于java ssm springboot网上蛋糕商城项目设计和实现 博主介绍:5年java开发经验,专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 超级帅帅吴 Java毕设项目精品实战案例《500套》 欢迎点赞 收藏 ⭐留言 文末获取源…

CAD中还能装ArcGIS?还能加载影像?定义坐标系?

时常我们需要CAD中插入影像 需要CAD数据转换GIS数据 需要CAD加载GIS数据 需要将CAD与GIS数据套库 却被坐标系搞蒙了 今天,我们就来解决以上的问题,介绍一款免费的ArcGIS插件——ArcGIS for AutoCAD。 这个模块插件可以直接访问在线地图。直接在CAD中…

Java实验——定义一个表示学生信息的类Student,要求如下:

一、题目要求 定义一个表示学生信息的类Student,要求如下: (1)类Student的成员变量: sNO 表示学号;sName表示姓名;sSex表示性别;sAge表示年龄;sJava:表示…

测试开发 | 如何模拟真实使用场景?mock 技术来帮你

mock 是一种通过代理修改请求与响应,从而辅助构造更多应用场景的工具。比如在工作中,可能需要 mock 第三方的回调给到测试人员测试的环境,从而更顺利的开展测试工作,也使得测试环境更接近真实的使用场景。Charles 修改请求与响应M…

Android自定义时间选择器

效果图 一、添加NumberPicker开源库 需要添加以下控件 仓库地址: https://github.com/ShawnLin013/NumberPicker implementation io.github.ShawnLin013:number-picker:2.4.13 二、 添加弹出框主题样式 在drawable文件夹下新建一个bg_bottom_dialog.xml&…

jenkins结合gitlable企业集成部署实战

简介 Jenkins是一个开源软件项目,起源于Hudson(Hudson是商用的),是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件项目可以进行持续集成 1.0 …

新的跨平台渲染引擎:Ab3d.DXEngine 5.2 Crack

用于 WPF 和 WinForms 的 DirectX 11 3D 渲染引擎 Ab3d.DXEngine 是一种超快的 3D 渲染引擎,可用于 .Net 桌面应用程序。采集 by Ω578867473 Ab3d.DXEngine采用超快的多线程渲染技术,可以充分利用显卡,提供与使用C时几乎相同的极致性能。 该…

javaEE 初阶 — 线程安全的集合类

文章目录1. 多线程环境使用 ArrayList多线程使用队列3. 多线程环境使用哈希表3.1 Hashtable3.2 ConcurrentHashMap4. 相关面试题1. 多线程环境使用 ArrayList java 标准库里的大部分集合类都是 “线程不安全” 的。 多个线程使用同一个集合类对象,很有可能会出问题。…

WebDAV之葫芦儿·派盘+Air Explorer

Air Explorer 支持WebDAV方式连接葫芦儿派盘。 电脑本地硬盘不够,网盘云存储已经成为存储的一种趋势。网盘限额,数据存在多个网盘内,操作麻烦还费事。 Airexplorer可以完美解决这个困扰。Air Explorer是一款非常不错的云存储账户管理软件,常见的在线云存储服务器都支持;还…

六道算法基础题详解

目录 1.力扣第217题:存在重复元素 2.力扣第53题:最大子数组和 3.力扣第1题:两数之和 4.力扣第88题:合并两个有序数组 5.牛客BM1题:反转链表 6.牛客BM2题:链表内指定区间反转 1.力扣第217题&#xff1…