发布于2020-03-18 11:13 阅读(1750) 评论(0) 点赞(20) 收藏(4)
算法 1:深度优先算法;
算法 2:宽度优先算法;
算法 3:代价一致算法;
算法 4:A* 算法;
算法1-4的不同之处在于用不同的数据结构进行排序。因此可以定义一个通用的搜索算法实现算法1-4,通过配置不同参数来实现DFS,BFS,UCS和A*搜索。
算法 | 数据结构 |
---|---|
DFS | 栈 |
BFS | 队列 |
代价一致 | 优先队列 |
A* | 优先队列+启发式函数 |
def genericSearchAlgorithm(problem, open_type):
"""
param1: problem (搜索算法要解决的问题对象)
param2: open_type (搜索算法中的open表采用的数据结构)
return值: actions列表,即,吃豆人吃到豆子所执行的一个action序列
"""
openTable = open_type() # 数据结构
# 将其实例化,创建open表
openTable.push((problem.getStartState(), []))
closed = [] # 初始化closed表为空表
while True:
if openTable.isEmpty():
return []
node,actions = openTable.pop()
if problem.isGoalState(node):
return actions
if node not in closed:
closed.append(node)
for successor,action, stepCost in problem.getSuccessors(node):
openTable.push((successor,actions+[action]))
深度优先搜索是最常见的搜索算法之一。DFS采用栈作为数据结构进行搜索路径,“先进后出”。
从起点出发,首先判断起点是否是目标节点,若是则返回目标节点。否则,搜索一条分支的所有结点,然后再去搜索其他分支。
首先判断节点是否是目标节点,若是则返回目标节点,否则压入栈中。若栈不为空,选择栈顶弹出的节点作为下一步的节点,依次类推,直至找到目标节点。若栈为空却未搜索到目标节点,则搜索失败。将通用搜索算法中的 open_type 设置为 util.Stack。
def depthFirstSearch(problem):
return generalSearch(problem, util.Stack)
广度优先搜索是最常见的搜索算法之一。BFS采用队列作为数据结构进行搜索路径,“先进先出”。
从起点出发,首先判断起点是否是目标节点,若是则返回目标节点。否则,搜索该节点的邻居节点,
首先判断节点是否是目标节点,若是则返回目标节点,否则压入队列中。
若队列不为空,选择队列中的首节点作为下一步的节点,依次类推,直至找到目标节点。若队列为空却未搜索到目标节点,则搜索失败。将通用搜索算法中的 open_type 设置为 util.Queue。
def breadthFirstSearch(problem):
return generalSearch(problem, util.Queue)
代价一致搜索是宽度优先搜索的一种推广, 不是沿着等长度路径逐层进行扩展, 而是沿着等代价路径逐层进行扩展。
在代价树中,可以用g(n)表示从初始节点S0到节点 i的代价,用 c(i, n2)表示从父节点 i到 n2的代价,记g(n2) = g(i) + c(i, n2)。
把从起始节点S0到任一节点i的路径代价记为g(i)。从初始节点S0开始扩展,若没有得到目标节点,则优先扩展最少代价g(i)的节点,一直如此向下搜索。将通用搜索算法中的 open_type 设置为util.PriorityQueue。
def uniformCostSearch(problem):
return generalSearch(problem, util.PriorityQueue, True)
f(n)是进过节点 n 的最小代价解的估计代价。
A*算法的估算函数为 f(n) = g(n) + h(n)。g(n)是到达此节点花费的代价, h(n)是从该节点到目标节点需要花费的代价(的估计值)。
def aStarSearch(problem, heuristic=nullHeuristic):
return generalSearch(problem, util.PriorityQueue, True, heuristic)
作者:编程gogogo
链接:https://www.pythonheidong.com/blog/article/265284/3c37f6212c5a03b31222/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!