我想在c中實現維基百科給出的*算法的僞代碼,但我真的被困在瞭解什麼是reconstruct_path函數,有人可以向我解釋什麼在這個函數中的變量(p ,p + current_node,set)表示?a *算法僞代碼
function A*(start,goal)
closedset := the empty set // The set of nodes already evaluated.
openset := {start} // The set of tentative nodes to be evaluated, initially containing the start node
came_from := the empty map // The map of navigated nodes.
g_score[start] := 0 // Cost from start along best known path.
// Estimated total cost from start to goal through y.
f_score[start] := g_score[start] + heuristic_cost_estimate(start, goal)
while openset is not empty
current := the node in openset having the lowest f_score[] value
if current = goal
return reconstruct_path(came_from, goal)
remove current from openset
add current to closedset
for each neighbor in neighbor_nodes(current)
tentative_g_score := g_score[current] + dist_between(current,neighbor)
if neighbor in closedset
if tentative_g_score >= g_score[neighbor]
continue
if neighbor not in openset or tentative_g_score < g_score[neighbor]
came_from[neighbor] := current
g_score[neighbor] := tentative_g_score
f_score[neighbor] := g_score[neighbor] + heuristic_cost_estimate(neighbor, goal)
if neighbor not in openset
add neighbor to openset
return failure
function reconstruct_path(came_from, current_node)
if came_from[current_node] in set
p := reconstruct_path(came_from, came_from[current_node])
return (p + current_node)
else
return current_node
謝謝
非常感謝您的回答,我還有一個問題:如果設置了came_from [current_node],行中設置了什麼? – user2102173 2013-03-02 18:53:01
我認爲它檢查結束條件,因爲它是一個遞歸函數。我認爲語義是「是否came_from [current_node]是列表中的最後一個節點?」 – Heisenbug 2013-03-02 19:00:36
謝謝,但是提到的是什麼列表:openset或者closedset或者其他什麼? – user2102173 2013-03-02 19:06:18