热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

八数码问题(头歌educoder启发式搜索)(python实现)

八数码问题(头歌educoder启发式搜索)(python实现)-任务描述本关任务:八数码问题是在一个3×3的棋盘上有1−8位数字随机分布,以及一个空格,与空格相连的棋子可以滑动到

任务描述
本关任务:八数码问题是在一个3×3的棋盘上有1−8位数字随机分布,以及一个空格,与空格相连的棋子可以滑动到空格中,问题的解是通过空格滑动,使得棋盘转化为目标状态,如下图所示。为了简化问题的输入,首先将空格用数字0表示,然后将3×3的棋盘用9位长的字符串表示,则上图的初始状态为724506831,目标状态为012345678,本关卡所有目标状态均为012345678,也保证初始状态到目标状态有解。

测试输入:
724506831 

这道题可以用很多搜索方法解决,启发式搜索为题目要求方法,但是因为评测的程序是只要有一条路径能够成功从输入走到"12345678"即可,于是也可以使用其他搜索方法也可以,比如深搜,广搜都可以,甚至不需要计算代价函数,无脑搜索就可以,但是后来发现不用代价值判断会超时,所以还是加入了代价函数的编写,由于不能贴完整代码,给大家一个模板,大家去写子函数把

深度优先搜索搜模板

子函数:
self.path1(index, i)  index位置是否能够移动
self.moveMap1(init, index, index + self.direction[i]) #index位置与index +direction[i] 交换后的序列
self.isseen(change) change序列是否被走过
self.calcDistH(change) 计算change到targ的代价值




class Solution:
    def __init__(self):
        self.set1 = set()
        self.seen = collections.defaultdict(int) #标记数组
        self.way= {0:'r',1:'l',2:'d',3:'u'}  #存储走的方向
        self.path =[]  #存储路径
        self.direction = (1, -1, 3, -3) #存储移动

    def salvePuzzle(self, init, targ):
        ''' 求解8数码问题
        参数:
        init - 初始状态 例如'123046758'
        targ - 目标状态 均为'012345678'
        返回值:
        clf - 由udlr组成的移动路径字符串
        '''
        return self.dfs(init, targ)

    def dfs(self, init, targ):
        initstr = ''.join(init)
        if (initstr == targ):  # 如果找到就返回
            return True
        self.seen[initstr] = 1  # 标记为走过
        nowvalue = self.calcDistH(init, targ)  # 计算当前的代价值
        index = init.index('0')  # 找到0的位置
        for i in range(4):  #遍历四种方向
            if (self.path1(index, i)):  # 如果能够交换
                change = self.moveMap1(init, index, index + self.direction[i])  #得到移动后的序列
                changevalue = self.calcDistH(change, targ)  #移动后的序列代价值
                if (changevalue<=nowvalue and self.isseen(change)):  #判断change是否走过
                    self.path.append(self.way[i])  #
                    if(self.dfs(change, targ)):
                        return self.path
                    self.path.pop()  #回溯
        return 0  
    
a=Solution()
str1 = input()
print(a.salvePuzzle(list(str1),"012345678")) #打印路径

广度优先搜索模板
明天写明天写

class Solution:
    def __init__(self):
        self.set1 = set()
        self.seen = collections.defaultdict(int)  # 标记数组
        self.way = {0: 'r', 1: 'l', 2: 'd', 3: 'u'}  # 存储走的方向
        self.direction = (1, -1, 3, -3)  # 存储移动
        self.queue = collections.deque()


    def salvePuzzle(self, init, targ):
        ''' 求解8数码问题
        参数:
        init - 初始状态 例如'123046758'
        targ - 目标状态 均为'012345678'
        返回值:
        clf - 由udlr组成的移动路径字符串
        '''
        self.queue.append((init, list())) #两个参数,一个初始序列与经过路径
        return self.bfs(targ)

    def bfs(self,targ):
        while self.queue:
            (init,path) = self.queue.popleft()
            initstr = ''.join(init)
            self.set1.add(initstr)  #标记为走过724506831
            if (initstr == targ):  #如果找到就返回
                return path
            nowvalue = self.calcDistH(init, targ)  # 计算当前的代价值
            index = init.index('0')  # 找到0的位置
            for i in range(4):  # 遍历四种方向
                if (self.path1(index, i)):  # 如果满足条件才进行下去):  # 如果能够交换
                    change = self.moveMap1(init, index,index + self.direction[i])  # 得到移动后的序列
                    changevalue = self.calcDistH(change, targ)  # 移动后的序列代价值
                    if (changevalue <= nowvalue and ''.join(change) not in self.set1):  # 判断change是否走过且代价值更小
                        temp = deepcopy(path)  #深拷贝防止在原数组上更改
                        temp.append(self.way[i])
                        self.queue.append((change,temp)) #加入队列
        return 0

截图

可以使用集合来纪录走过的路径,与这道题测试和题目是一样的,宽搜可以找到最优的,但是运行时间有点长,但

bfs+dfs:
将两个写在一起,但是代码有点冗长


推荐阅读
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 提升Python编程效率的十点建议
    本文介绍了提升Python编程效率的十点建议,包括不使用分号、选择合适的代码编辑器、遵循Python代码规范等。这些建议可以帮助开发者节省时间,提高编程效率。同时,还提供了相关参考链接供读者深入学习。 ... [详细]
  • Learning to Paint with Model-based Deep Reinforcement Learning
    本文介绍了一种基于模型的深度强化学习方法,通过结合神经渲染器,教机器像人类画家一样进行绘画。该方法能够生成笔画的坐标点、半径、透明度、颜色值等,以生成类似于给定目标图像的绘画。文章还讨论了该方法面临的挑战,包括绘制纹理丰富的图像等。通过对比实验的结果,作者证明了基于模型的深度强化学习方法相对于基于模型的DDPG和模型无关的DDPG方法的优势。该研究对于深度强化学习在绘画领域的应用具有重要意义。 ... [详细]
  • 本文介绍了Python对Excel文件的读取方法,包括模块的安装和使用。通过安装xlrd、xlwt、xlutils、pyExcelerator等模块,可以实现对Excel文件的读取和处理。具体的读取方法包括打开excel文件、抓取所有sheet的名称、定位到指定的表单等。本文提供了两种定位表单的方式,并给出了相应的代码示例。 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • Excel数据处理中的七个查询匹配函数详解
    本文介绍了Excel数据处理中的七个查询匹配函数,以vlookup函数为例进行了详细讲解。通过示例和语法解释,说明了vlookup函数的用法和参数的含义,帮助读者更好地理解和运用查询匹配函数进行数据处理。 ... [详细]
  • 本文介绍了如何使用python从列表中删除所有的零,并将结果以列表形式输出,同时提供了示例格式。 ... [详细]
  • 本文介绍了在使用Python中的aiohttp模块模拟服务器时出现的连接失败问题,并提供了相应的解决方法。文章中详细说明了出错的代码以及相关的软件版本和环境信息,同时也提到了相关的警告信息和函数的替代方案。通过阅读本文,读者可以了解到如何解决Python连接服务器失败的问题,并对aiohttp模块有更深入的了解。 ... [详细]
  • Go语言实现堆排序的详细教程
    本文主要介绍了Go语言实现堆排序的详细教程,包括大根堆的定义和完全二叉树的概念。通过图解和算法描述,详细介绍了堆排序的实现过程。堆排序是一种效率很高的排序算法,时间复杂度为O(nlgn)。阅读本文大约需要15分钟。 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • WhenIusepythontoapplythepymysqlmoduletoaddafieldtoatableinthemysqldatabase,itdo ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
  • 本文介绍了使用哈夫曼树实现文件压缩和解压的方法。首先对数据结构课程设计中的代码进行了分析,包括使用时间调用、常量定义和统计文件中各个字符时相关的结构体。然后讨论了哈夫曼树的实现原理和算法。最后介绍了文件压缩和解压的具体步骤,包括字符统计、构建哈夫曼树、生成编码表、编码和解码过程。通过实例演示了文件压缩和解压的效果。本文的内容对于理解哈夫曼树的实现原理和应用具有一定的参考价值。 ... [详细]
  • 十大经典排序算法动图演示+Python实现
    本文介绍了十大经典排序算法的原理、演示和Python实现。排序算法分为内部排序和外部排序,常见的内部排序算法有插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。文章还解释了时间复杂度和稳定性的概念,并提供了相关的名词解释。 ... [详细]
  • Python使用Pillow包生成验证码图片的方法
    本文介绍了使用Python中的Pillow包生成验证码图片的方法。通过随机生成数字和符号,并添加干扰象素,生成一幅验证码图片。需要配置好Python环境,并安装Pillow库。代码实现包括导入Pillow包和随机模块,定义随机生成字母、数字和字体颜色的函数。 ... [详细]
author-avatar
mobiledu2502876293
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有