作業フローを簡素化:miniwebtoolを検索。
追加
ホームページ > 数学 > 高度な数学操作 > ハミルトン路チェッカー
 

ハミルトン路チェッカー

グラフにハミルトン路またはハミルトン閉路が含まれているかどうかを確認します。Warnsdorffの枝刈りを用いたバックトラッキングを実行し、連結性と次数の必要条件を検証し、DiracとOreの十分条件をテストして、アニメーションSVGビジュアライゼーションで証拠となるパスを表示します。

ハミルトン路チェッカー
A-B, A->B, A B, A,B、または行列の行(例: 0 1 1 0)を受け付けます。ラベルには英数字またはアンダースコアを使用してください。
カンマまたはスペース区切りのラベル(1行に1つ)。省略した場合は自動的に A, B, C… となります。

Embed ハミルトン路チェッカー Widget

ハミルトン路チェッカー

ハミルトン路チェッカーは、グラフがハミルトン路(すべての頂点をちょうど1回ずつ訪れるシーケンス)またはハミルトン閉路(ハミルトン路に加えて、開始頂点に戻るもの)を含んでいるかどうかを判定します。このツールは、高速な構造的事前チェック(連結性、次数の前提条件、ディラックの定理、オレの定理)と、ワーンスドルフのヒューリスティックによって調整されたバックトラッキング探索を組み合わせ、証拠パスをステップバイステップのアニメーションで可視化します。

ハミルトン路とは?

頂点数 n のグラフ G = (V, E) において、ハミルトン路とは、すべての頂点を含む順序付きシーケンス v1, v2, …, vn であり、連続する各ペア (vi, vi+1)G のエッジであり、すべての頂点がちょうど1回ずつ現れるものを指します。さらに (vn, v1) もエッジである場合、そのシーケンスはハミルトン閉路となります。

ハミルトン路: v1 — v2 — v3 — … — vn (すべて異なり、隣接ペアはエッジ) ハミルトン閉路: v1 — v2 — v3 — … — vn — v1 (始点に戻る)

この問題は、1857年に正十二面体グラフのすべての頂点をちょうど1回ずつ訪れる閉路を見つけるパズル「イコシアン・ゲーム」を考案したウィリアム・ローワン・ハミルトンにちなんで名付けられました。

難しさの理由: NP完全性

ハミルトン路判定問題およびハミルトン閉路判定問題は、どちらもNP完全です (Karp, 1972)。P = NP でない限り、あらゆるインスタンスを多項式時間で解くアルゴリズムは存在しません。最悪の場合、バックトラッキングは閉路に対して最大 (n−1)! サイズの探索木を探索します。このため、この電卓は入力を20頂点までに制限しています。頂点数 n がわずかに増加するだけで、実行時間は爆発的に増加するためです。

実際には、ワーンスドルフのヒューリスティック(もともとは1823年にハインリヒ・ワーンスドルフが騎士の巡回問題のために考案したもの)を用いることで、構造化されたグラフ上での探索が劇的に高速化されます。各ステップで、アルゴリズムは未訪問の隣接頂点のうち、残りの未訪問隣接頂点数が最も少ない頂点へパスを延長します。この貪欲法的な規則により、探索が行き止まりに陥るのを防ぎ、素直なグラフではバックトラッキングなしでハミルトン巡回路を発見できることがよくあります。

必要条件 — 高速な棄却

コストの高い探索を実行する前に、電卓はハミルトン路を含む可能性がないグラフを棄却します:

これらの規則により、絶望的な入力を線形時間で棄却し、無駄なバックトラッキングの労力を避けることができます。

十分条件 — 古典的定理

いくつかの古典的な定理は、単純無向グラフにハミルトン閉路が存在することを保証する十分(ただし必要ではない)条件を与えます。これらが適用される場合、電卓は探索を実行せずに(証拠となる閉路は提示しますが)結果を「保証あり」とマークします。

ディラックの定理 (1952年)

Gn ≥ 3 の単純無向グラフであり、すべての頂点の次数が n / 2 以上であれば、G はハミルトン閉路を持ちます。

δ(G) ≥ n / 2 ⟹ G はハミルトン的

オレの定理 (1960年)

隣接していないすべての頂点ペア uv について deg(u) + deg(v) ≥ n が成り立つなら、G はハミルトン閉路を持ちます。オレの条件はディラックの条件よりも厳密に弱いため、オレの定理が成り立つときはディラックの定理も成り立ちます。

∀ 非隣接 u, v: deg(u) + deg(v) ≥ n ⟹ G はハミルトン的

ディラックまたはオレの条件を満たさないからといって、グラフにハミルトン閉路がないわけではありません。どちらも満たさないが閉路を持つグラフは多く存在します(例:単純な n 角形の閉路は最小次数が2であり、大きな n に対して n/2 よりもはるかに小さくなります)。

内部の探索アルゴリズム

事前チェックで決着がつかない場合、電卓はグラフの隣接表現に対してバックトラッキング探索を実行します。主な手法:

  1. ビットマスクによる訪問済みセット: 訪問した頂点をビットマスクとして保存します(最大20頂点まで、O(1) の高速な所属判定が可能)。
  2. ワーンスドルフのヒューリスティック: 各延長において、残りの未訪問次数が少ない順に隣接頂点を試行し、「分岐の少ない」順序を模倣します。
  3. ルート選択: ハミルトン閉路の場合、開始頂点は1つだけで十分です(閉路は回転不変であるため)。ハミルトンの場合、出次数が少ない(希少な位置)順に開始頂点を試行します。
  4. ステップ予算: ハードキャップにより、病的なインスタンスが無期限に実行されるのを防ぎます。予算を使い果たした場合、UI は「タイムアウト」と報告します。

ハミルトン vs オイラー

ハミルトン問題とオイラー問題は混同されやすいですが、根本的に異なります:

特性 ハミルトン路 / 閉路 オイラー路 / 閉路
通過するもの 各頂点をちょうど1回 各エッジをちょうど1回
計算複雑性 NP完全 多項式時間 (O(n+m))
判定条件 単純な特徴付けがない 連結 + すべての次数が偶数(閉路の場合)、奇数次数が2つ以下(路の場合)
名前の由来 W. R. ハミルトン (1857年) L. オイラー (1736年、ケーニヒスベルクの橋)
古典的な例 巡回セールスマン、イコシアン・ゲーム ルート点検、郵便配達員問題

サポートされている入力形式

エッジリスト

1行に1つのエッジ、またはカンマ区切り。サポートされている区切り文字:A-B, A B, A,B, A--B, A->B, A<-B。有向グラフであることを強制するには -> を使用してください。

A-B, B-C, C-D, D-A, A-C (5つのエッジを持つ無向グラフ) A->B, B->C, C->D, D->A (有向4角形閉路)

隣接行列

0/1値の正方行列。1行に1行分を入力し、スペースまたはカンマで区切ります。「行列ラベル」フィールドにオプションのラベルを入力できます。入力がない場合は、自動的に A, B, C… が使用されます。

0 1 1 0 1 0 1 1 1 1 0 1 0 1 1 0

このチェッカーの使い方

  1. 入力形式を選択 — 手書きの小さなグラフには「エッジリスト」、コードや教科書からの貼り付けには「隣接行列」を選択します。
  2. グラフを貼り付ける — テキストエリアにグラフを入力します。行列入力の場合は、任意で頂点ラベルを指定できます。
  3. チェック対象を選択 — 路のみ、閉路のみ、または一度に両方をチェックするか選択します。
  4. グラフの種類を選択 — 「自動検出」は、矢印のスタイル (->) や行列の対称性から有向性を推測します。
  5. 「ハミルトン性をチェック」をクリック — 結果ページには、判定の見出し、必要条件の事前チェック、ディラック/オレの十分条件テスト、証拠パス(存在する場合)、およびインタラクティブな可視化が表示されます。
  6. 証拠を再生 — 再生/ステップコントロールを使用して、グラフ上でエッジが1つずつ点灯する様子を確認します。

実行例 — ピーターセングラフ

有名なピーターセングラフ(10頂点、15エッジ、3-正則グラフ)は、ハミルトン路は持ちますがハミルトン閉路は持たないグラフの教科書的な例です。以下のエッジリストをフィールドに貼り付けてチェックをクリックしてください:

1-2, 2-3, 3-4, 4-5, 5-1, 6-8, 8-10, 10-7, 7-9, 9-6, 1-6, 2-7, 3-8, 4-9, 5-10

チェッカーは確認します:ハミルトン路は発見されます(例: 1 — 2 — 7 — 10 — 5 — 4 — 9 — 6 — 8 — 3)が、網羅的探索によりループを閉じる方法がないことが判明します。これは1890年代に最初に証明された結果です。

主な用途

よくある質問

ハミルトン路とは何ですか?

ハミルトン路とは、グラフのすべての頂点をちょうど1回ずつ通る道のことです。1857年に正十二面体グラフ上の問題を研究したウィリアム・ローワン・ハミルトンにちなんで名付けられました。このような路が存在するかどうかの判定は NP完全問題であり、すべてのグラフに対して多項式時間で解く既知のアルゴリズムは存在しません。

ハミルトン閉路とハミルトン路の違いは何ですか?

ハミルトン閉路は、開始頂点に戻るハミルトン路のことで、すべての頂点をちょうど1回ずつ訪れる閉じたループを形成します。すべてのハミルトン閉路にはハミルトン路が含まれますが(終点のエッジを除去すればよいため)、その逆は真ではありません。多くのグラフはハミルトン路を持ちますが、ハミルトン閉路は持ちません。

ディラックの定理とは何ですか?

ディラックの定理(1952年)は、nが3以上の頂点を持つ単純無向グラフにおいて、すべての頂点の次数が n/2 以上であれば、そのグラフはハミルトン閉路を持つというものです。これは十分条件ですが必要条件ではありません。ディラックの閾値を満たさない多くのグラフも、ハミルトン閉路を持つことがあります。

オレの定理とは何ですか?

オレの定理(1960年)は、nが3以上の頂点を持つ単純グラフにおいて、隣接していないすべての頂点のペア u と v について、その次数の和が n 以上であれば、そのグラフはハミルトン閉路を持つというものです。オレの条件はディラックの条件よりも弱いため、オレの定理が適用される場合は常にオレの定理も適用されます。

なぜ探索は20頂点に制限されているのですか?

ハミルトン路および閉路の判定問題は NP完全です。最悪の場合の実行時間は頂点数に対して指数関数的に増加します。プルーニングとワーンスドルフのヒューリスティックにより、この電卓は20頂点までの多くの小規模グラフを迅速に処理できますが、より困難なケースではタイムアウトする可能性があります。20頂点を超える場合は、Concordeや整数計画法などの専門的なソルバーを使用する必要があります。

ワーンスドルフのヒューリスティックとは何ですか?

1823年に騎士の巡回問題のために提案されたワーンスドルフの規則は、各ステップで、まだ訪問していない隣接頂点のうち、未訪問の隣接頂点が最も少ない頂点に移動すべきであるというものです。この貪欲法的な規則は、実際にはバックトラッキングの探索木を劇的に剪定し、正則グラフなどではバックトラッキングなしでハミルトン路を見つけることもよくあります。

このツールはすべてのハミルトン路を見つけますか?

いいえ — 存在する場合に、証拠となる1つの路または閉路を見つけます。ハミルトン路の総数を数えることは、それ自体が #P完全問題であり、判定問題よりもはるかに困難です。列挙が必要な場合は、専用のツールや整数計画ソルバーが適しています。

参考文献

このコンテンツ、ページ、またはツールを引用する場合は、次のようにしてください:

"ハミルトン路チェッカー"(https://MiniWebtool.com/ja/ハミルトン路チェッカー/) MiniWebtool からの引用、https://MiniWebtool.com/

by miniwebtool チーム. 更新日: 2026年4月21日

また、AI 数学ソルバー GPT を使って、自然言語による質問と回答で数学の問題を解決することもできます。

その他の関連ツール:

高度な数学操作:

おすすめ:

標準偏差電卓 - 高精度パーセント増加電卓パーセンテージ減少電卓war電卓ランダムカラージェネレーターランダム誕生日ジェネレーター合計電卓HEX電卓パーセント誤差電卓円錐展開図テンプレートジェネレーター番号を並べ替えるai句読点追加画像分割ツール英単語ランダム生成ツール中央値電卓フィートとインチからセンチメートルへのコンバーター売上総利益率電卓マスターナンバー電卓手数料電卓MACアドレス検索YouTubeチャンネル統計対数電卓シグマ記法電卓 総和動画を逆再生CAGR電卓筆算割り算電卓弧長電卓迷路ジェネレーターランダム絵文字ジェネレーターランダム名前ジェネレーターランダム音周波数ジェネレーター分散電卓 高精度血糖値コンバーターt検定電卓動画を結合マン・ホイットニーのU検定計算機ボウリングスコア計算機変化率電卓ASCIIコード表小数時間から普通の時間へのコンバーター相対標準偏差電卓ランダム日付ジェネレーターセンチメートルからフィートとインチへのコンバーターMP3ルーパー動画を回転逆テキストlog-base-2電卓配当利回り電卓楕円円周電卓コラッツ予想電卓空の行を削除するFPSコンバーターランダムトーナメント表作成ツール平方完成電卓ランダムポーカーハンドジェネレーター指数電卓-高精度相関係数計算機SRT 時間シフト 電卓トルク電卓BUN対クレアチニン比電卓デシベル (dB) 電卓上下反転テキストジェネレーター音節カウンター平方根電卓ビンゴカードジェネレーターモジュロ電卓クロスワードパズルメーカーランダム名ピッカー労働時間計算ツールCRC32チェックサム電卓💧 露点電卓年の日電卓 - 今日は今年の何日目圧力電卓バイナリ電卓関数グラフ作成ツールInstagramユーザーID検索エンジェルナンバー電卓階段電卓fena電卓土星回帰電卓歩数距離変換電卓ランダムトランプカードジェネレーター関数電卓桁数電卓斜辺電卓複数分数電卓10進数からBCDへのコンバーター並列抵抗電卓逆ラプラス変換電卓パラメトリック曲線グラフ作成ツールピタゴラスの定理電卓表面積電卓🎮 ゲーム感度変換器太陽・月・上昇星座電卓 🌞🌙✨平均電卓-高精度アナグラム生成器ランダム超能力ジェネレーターSRTからTXTへの変換ツール梁の電卓配管流量電卓そろばんシミュレーターロシア農民式乗算ヴェーダ数学トリック電卓古代エジプト式乗算電卓ローマ数字計算ソルバー暗算トレーナー九九クイズ繰り上がりと繰り下がりビジュアライザー数の合成と分解生成ツール硬貨文章題ソルバー距離・速さ・時間の三角形電卓仕事算ソルバー混合問題ソルバー年齢文章題ソルバー列車出会い問題ソルバー水分補給計算機ペース カロリー電卓薬剤投与量計算機アルコールカロリー電卓ボディリコンポジション電卓ランダム討論トピックジェネレーターランダムな猫犬の名前ジェネレーターランダム聖句ジェネレーターランダム算数問題ジェネレーターランダム段落ジェネレーターランダム英文ジェネレーター砂利・砂・表土計算機鋼材重量電卓ボルト締付トルク計算機ドルから金への変換ツールオプション電卓株式分割電卓ESPP電卓請求書遅延手数料電卓フリーランス時給電卓リース対購入電卓高度なチップ割り勘電卓持ち物リストジェネレーター時差ぼけ電卓旅行予算電卓飛行距離電卓熱損失電卓発電コスト電卓水使用量電卓家電電気代計算機家庭エネルギー監査電卓太陽光ROI電卓太陽光パネル電卓堆肥cn比計算機芝生肥料電卓霜の日付電卓レイズドベッド用土電卓NPK肥料電卓種子発芽率電卓動画ビットレート電卓音楽キー移調ツール音楽BPMタッパー写真ファイルサイズ推定電卓メガピクセルから印刷サイズ計算機クロップファクター電卓露出トライアングル電卓車両牽引能力電卓カーリース計算機0–60とクォーターマイル電卓EV充電時間電卓EV航続距離計算機燃費計算機服のサイズ変換用紙サイズ一覧指輪サイズ変換器天文単位変換器燃費変換ツール MPG L/100km km/L 電卓データ転送速度変換ツールトルク変換器 (Nm, ft-lb, kgf-cm)取り消し線テキスト生成ツール空白文字可視化ツール読書時間電卓スピーチ時間電卓段落カウンター文カウンターテキストからバイナリ/16進数/ASCII変換器Lorem Picsum / プレースホルダー画像ジェネレーター.env ファイルジェネレーターGitコマンド生成ツールカラーコード変換器全形式bcryptハッシュ生成・検証ツールJWTジェネレーターCSS Grid生成ツール数値積分電卓z変換電卓高速フーリエ変換FFT電卓テンソル積電卓行列指数関数電卓ジョルダン標準形電卓環と体の電卓群論の位数電卓常微分方程式系ソルバーベルヌーイ方程式ソルバーオイラー法電卓方向場・傾き場プロッター二階常微分方程式ソルバー一階常微分方程式ソルバー安定結婚問題ソルバーネットワークフロー電卓最大フロー平面グラフ判定ハミルトン路チェッカー巡回セールスマン問題ソルバー TSP線形計画法ソルバー包除原理電卓漸化式ソルバー隣接行列電卓トポロジカルソート電卓グラフ彩色電卓論理ゲートシミュレーターカルノー図 (K-Map) ソルバーブール代数簡略化ツール分割数電卓デジタルルート電卓フィボナッチ数チェッカーエジプト分数電卓メビウス関数電卓ゴールドバッハ予想検証ツールメルセンヌ素数チェッカー双子素数ファインダー友愛数チェッカー完全数チェッカーモジュラー冪乗計算機重複順列電卓効果量電卓相対リスク電卓オッズ比電卓分割表電卓フィッシャーの正確確率検定電卓スピアマン順位相関係数計算機ベータ分布電卓ワイブル分布電卓指数分布電卓幾何分布電卓負の二項分布電卓超幾何分布電卓F検定・F分布電卓ベイズの定理電卓固有多項式計算機行列べき乗電卓コレスキー分解電卓QR分解電卓行列対角化電卓クラメルの公式電卓列空間電卓零空間電卓ベクトル間の角度電卓単位ベクトル電卓ベクトルの大きさ電卓外積電卓内積電卓行列の掛け算電卓逆行列電卓RREF計算機行簡約階段形ニュートン法電卓ヤコビ行列電卓面積分電卓線積分計算機回転カール電卓発散計算機勾配計算機多変数最適化電卓微積分関連変化率ソルバー瞬間変化率電卓平均変化率計算機無限級数和電卓級数収束判定電卓べき級数電卓マクローリン級数電卓ロピタルの定理計算機広義積分電卓シンプソン則電卓台形公式電卓リーマン和電卓回転体の表面積計算機回転体の体積電卓座標幾何距離計算機ヘロンの公式計算機円の接線電卓角の二等分線電卓内接円インサークル電卓外接円電卓大圏距離計算機3d距離電卓トーラス電卓円錐台電卓不規則多角形面積電卓正多角形電卓円錐曲線識別ツール双曲線電卓放物線電卓二項定理展開電卓パスカルの三角形ジェネレーター積の記号電卓 (Π パイ記法)有理根定理 電卓デカルトの符号法則電卓平行線と垂直線の電卓直線の方程式電卓標準形から傾き切片形への変換点傾き形式電卓非線形連立方程式ソルバー有理方程式ソルバー文字式方程式ソルバー三角方程式ソルバー指数方程式ソルバー対数方程式ソルバー四次方程式計算機三次方程式ソルバー概算電卓数値から分数への変換器スキップカウントジェネレーター単価電卓天井関数と床関数 電卓絶対値電卓数列パターン検出ツール位取り表ジェネレーター演算の順序電卓PEMDAS筆算足し算・引き算計算機筆算かけ算計算機九九表ジェネレーター🎮 ゲーム内通貨変換器🎲 ドロップ確率電卓🎰 ガチャ天井計算機⚔️ DPS電卓❄️ 雪の日計算機🚚 引っ越し費用見積もり🔍 盗作チェッカー📷 OCR / 画像からテキスト抽出📈 折れ線グラフ作成ツール🥧 円グラフ作成ツール📊 棒グラフ作成ツール🔊 トーンジェネレーター🖱️ クリックカウンターオンラインメモ帳⬛ アスペクト比電卓🌍 カーボンフットプリント電卓👙 ブラサイズ電卓タイヤサイズ電卓燃料費電卓🌡️ 暑さ指数電卓🌬️ 体感温度電卓⏰ オンラインアラーム時計⏰ タイムカード電卓📅 日付差分電卓🕐 ミリタリータイム変換器⏱️ 時間計算機⏱️ オンラインストップウォッチ⏱️ カウントダウンタイマー🌐 タイムゾーン変換器カーペット計算機擁壁電卓HVAC容量計算電卓断熱材電卓ペーバー電卓鉄筋電卓木材計算機平方フィート計算機交差掛け算電卓五数要約電卓パーセンタイル電卓正規分布電卓p値電卓比率電卓四捨五入電卓Twitter/X 文字数カウンターYouTubeコメントピッカーYouTubeタグ抽出ツールyoutubeサムネイルダウンローダーyoutube収益見積もりツールランダムRPGキャラクタージェネレーター