python实现三消游戏(消消乐)算法--简单案例

2024-03-10 17:32

本文主要是介绍python实现三消游戏(消消乐)算法--简单案例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

三消算法首要实现的就是找到所有三个或三个以上的同样颜色,所以我们思路是:判断每个点进行上下左右四个方向移动后,能得到三个及以上的相连。

经过分析,当我们向一个方向移动时,会有四种情况符合条件,所以当一个点符合消除时,需要判断周围点的情况共有16种!

例如:当红色圈向右移动一格能消除时,他周围的情况必然时图下四种状态:

1.与右边两个绿圈消除

2.与右上方两个蓝圈消除

3.与右下方两个黄圈消除

4.与右边上下各一个绿色正方形消除。

所以,我们的要做的是:

第一步:

将图片转换成矩阵:

list_ = [["绿", "红", "红", "紫", "绿", "紫", "蓝"],["紫", "紫", "绿", "黄", "绿", "蓝", "紫"],["紫", "红", "紫", "红", "紫", "蓝", "黄"],["蓝", "紫", "紫", "蓝", "黄", "紫", "绿"],["红", "蓝", "绿", "紫", "黄", "蓝", "绿"]]

第二步:

从上往下,从左往右,遍历每一个点,并且遍历它周围的特定位置,判断是否移动该点,能和周围的点结合实现消除。

用于算法计算的坐标轴:

第三步:

代码实现:

list_ = [["绿", "红", "红", "紫", "绿", "紫", "蓝"],["紫", "紫", "绿", "黄", "绿", "蓝", "紫"],["紫", "红", "紫", "红", "紫", "蓝", "黄"],["蓝", "紫", "紫", "蓝", "黄", "紫", "绿"],["红", "蓝", "绿", "紫", "黄", "蓝", "绿"]]# 横坐标为x,纵坐标为y
def main_method(list_):for x in range(7):for y in range(5):# 获取该坐标点的颜色c = list_[y][x]print(x, y, c)# 判断该坐标向右移是否满足(考虑越界问题,需判断坐标变换后是否在矩阵内)if ((y - 1) >= 0 and (x + 1) <= 6 and (y + 1) <= 4 and list_[y - 1][x + 1] == c and list_[y + 1][x + 1] == c) or ((x + 2) <= 6 and (x + 3) <= 6 and list_[y][x + 2] == c and list_[y][x + 3] == c) or ((y - 1) >= 0 and (x + 1) <= 6 and (y - 2) >= 0 and list_[y - 1][x + 1] == c and list_[y - 2][x + 1] == c) or ((y + 1) <= 4 and (x + 1) <= 6 and (y + 2) <= 4 and list_[y + 1][x + 1] == c and list_[y + 2][x + 1] == c):print("请将[%s,%s]右移" % (x, y))return [x, y, '右移']# 判断该坐标向左移是否满足elif ((y - 1) >= 0 and (x - 1) >= 0 and (y + 1) <= 4 and list_[y - 1][x - 1] == c and list_[y + 1][x - 1] == c) or ((x - 2) >= 0 and (x - 3) >= 0 and list_[y][x - 2] == c and list_[y][x - 3] == c) or ((y - 1) >= 0 and (x - 1) >= 0 and (y - 2) >= 0 and list_[y - 1][x - 1] == c and list_[y - 2][x - 1] == c) or ((y + 1) <= 4 and (x - 1) >= 0 and (y + 2) <= 4 and list_[y + 1][x - 1] == c and list_[y + 2][x - 1] == c):print("请将[%s,%s]左移" % (x, y))return [x, y, '左移']# 判断该坐标向上移是否满足elif ((y - 1) >= 0 and (x - 1) >= 0 and (x + 1) <= 6 and list_[y - 1][x - 1] == c and list_[y - 1][x + 1] == c) or ((y - 2) >= 0 and (y - 3) >= 0 and list_[y - 2][x] == c and list_[y - 3][x] == c) or ((y - 1) >= 0 and (x - 1) >= 0 and (x - 2) >= 0 and list_[y - 1][x - 1] == c and list_[y - 1][x - 2] == c) or ((x + 1) <= 6 and (x + 2) <= 6 and (y - 1) >= 0 and list_[y - 1][x + 1] == c and list_[y - 1][x + 2] == c):print("请将[%s,%s]上移" % (x, y))return [x, y, '上移']# 判断该坐标向下移是否满足elif ((y + 1) <= 4 and (x - 1) >= 0 and (x + 1) <= 6 and list_[y + 1][x - 1] == c and list_[y + 1][x + 1] == c) or ((y + 2) <= 4 and (y + 3) <= 4 and list_[y + 2][x] == c and list_[y + 3][x] == c) or ((y + 1) <= 4 and (x - 1) >= 0 and (x - 2) >= 0 and list_[y + 1][x - 1] == c and list_[y + 1][x - 2] == c) or ((x + 1) <= 6 and (x + 2) <= 6 and (y + 1) <= 4 and list_[y + 1][x + 1] == c and list_[y + 1][x + 2] == c):print("请将[%s,%s]下移" % (x, y))return [x, y, '下移']else:print("不满足")continuereturn ['无有效移动']if __name__ == '__main__':main_method(list_)

运行结果:(起始坐标点为[0,0])

这篇关于python实现三消游戏(消消乐)算法--简单案例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/794976

相关文章

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

Python使用Pandas对比两列数据取最大值的五种方法

《Python使用Pandas对比两列数据取最大值的五种方法》本文主要介绍使用Pandas对比两列数据取最大值的五种方法,包括使用max方法、apply方法结合lambda函数、函数、clip方法、w... 目录引言一、使用max方法二、使用apply方法结合lambda函数三、使用np.maximum函数

MySQL8.0设置redo缓存大小的实现

《MySQL8.0设置redo缓存大小的实现》本文主要在MySQL8.0.30及之后版本中使用innodb_redo_log_capacity参数在线更改redo缓存文件大小,下面就来介绍一下,具有一... mysql 8.0.30及之后版本可以使用innodb_redo_log_capacity参数来更改

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2