アルゴリズムを実装するためにヒープ キューを使用しています。新しいノードをキューに追加すると、ヒューリスティック関数によって並べ替えられます。キューから次のノードをポップするときに、最初に追加されたノードではなく、最後に追加されたノードが必要であるという事実から、heappop が返します。キューを壊さずにキューに追加された最新のノードを取得するにはどうすればよいですか?
最初の要素から反復を開始し、次の要素のスコアが同じである間は続行できると思います。次に、そのスコアを持つ最後の要素を見つけたら、それを選択してリストから削除します。これは明らかにあまり効率的ではなく、優先キューの時間の複雑さを解消しますか?
私はこれに行き詰まっており、それを行う方法がわかりません。
ありがとう。
編集; 提案されているようにカウンターを使用しても機能しません(おそらく私は誤解しています)
>>> queue = []
>>> heappush(queue, (2, 0, 'a'))
>>> heappush(queue, (3, -1, 'b'))
>>> queue
[(2, 0, 'a'), (3, -1, 'b')]
>>> heappush(queue, (2, -2, 'c'))
>>> queue
[(2, -2, 'c'), (3, -1, 'b'), (2, 0, 'a')]
現在、キューの順序が正しくなく、'a' よりも悪いオプションである 'b' がその前に配置されています。
編集2:
なんてこったい?
>>> heappop(queue)
(2, -2, 'c')
>>> queue
[(2, 0, 'a'), (3, -1, 'b')]
>>>