Haskellのカレンダー | Advent Calendar 2022 - Qiita に参加させていただきます! 突然ですが Haskell でダイクストラ法を実装します。 ダイクストラ法は重み付きグラフで最短経路問題を解くアルゴリズムのひとつです。ダイクストラ法 - Wikipedia に詳しい解説があります。 ダイクストラ法は、重み付きグラフにおいて、その重みに負の値がない・・・つまり重みが正であることを前提にしています。この構造上の仮定によって、貪欲的手法を取ることができるのがその特徴で、結果ベルマン・フォード法などの汎用的なアルゴリズムよりも計算量的に有利になります。 ダイクストラ法では、始点から各頂点への到達コストを最初に \infty と置いて、そこから緩和操作によって徐々にそれらを最適コストまで収束させていくわけですが、このとき グラフの頂点集合からその時点で最小のコスト
![Haskell で、優先度付きキューを使ったダイクストラ法](https://cdn-ak-scissors.b.st-hatena.com/image/square/812d42eef1e5682b400ad6e1be9bf6825173513b/height=288;version=1;width=512/https%3A%2F%2Fres.cloudinary.com%2Fzenn%2Fimage%2Fupload%2Fs--qhs7-2vq--%2Fc_fit%252Cg_north_west%252Cl_text%3Anotosansjp-medium.otf_55%3AHaskell%252520%2525E3%252581%2525A7%2525E3%252580%252581%2525E5%252584%2525AA%2525E5%252585%252588%2525E5%2525BA%2525A6%2525E4%2525BB%252598%2525E3%252581%25258D%2525E3%252582%2525AD%2525E3%252583%2525A5%2525E3%252583%2525BC%2525E3%252582%252592%2525E4%2525BD%2525BF%2525E3%252581%2525A3%2525E3%252581%25259F%2525E3%252583%252580%2525E3%252582%2525A4%2525E3%252582%2525AF%2525E3%252582%2525B9%2525E3%252583%252588%2525E3%252583%2525A9%2525E6%2525B3%252595%252Cw_1010%252Cx_90%252Cy_100%2Fg_south_west%252Cl_text%3Anotosansjp-medium.otf_37%3Anaoya_ito%252Cx_203%252Cy_121%2Fg_south_west%252Ch_90%252Cl_fetch%3AaHR0cHM6Ly9saDMuZ29vZ2xldXNlcmNvbnRlbnQuY29tL2EtL0FPaDE0R2lPejJjRnRRVXFpRTgtMUZWRGRRN2xrNFV2VXp1QXBIZTBwVnFxZUE9czk2LWM%3D%252Cr_max%252Cw_90%252Cx_87%252Cy_95%2Fv1627283836%2Fdefault%2Fog-base-w1200-v2.png)