作業フローを簡素化: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電卓MACアドレス検索円錐展開図テンプレートジェネレーター画像分割ツール売上総利益率電卓弧長電卓クロスワードパズルメーカー空の行を削除するランダム名前ジェネレーター英単語ランダム生成ツール番号を並べ替える中央値電卓対数電卓分散電卓 高精度CAGR電卓楕円円周電卓👙 ブラサイズ電卓InstagramユーザーID検索逆テキスト手数料電卓小数時間から普通の時間へのコンバーターYouTubeチャンネル統計FPSコンバーター迷路ジェネレーター平方完成電卓MP3ルーパー動画を逆再生動画を結合センチメートルからフィートとインチへのコンバーター関数電卓ai句読点追加積分電卓上下反転テキストジェネレーター平方根電卓エンジェルナンバー電卓相対標準偏差電卓モジュロ電卓血糖値コンバーターマスターナンバー電卓ASCIIコード表log-base-2電卓指数電卓-高精度ランダム超能力ジェネレーター労働時間計算ツールボウリングスコア計算機変動係数電卓ランダム名ピッカーXMLバリデーターt検定電卓バイナリ電卓相関係数計算機デシベル (dB) 電卓圧力電卓ランダム日付ジェネレーター💧 露点電卓ビンゴカードジェネレーター歩数距離変換電卓並列抵抗電卓SRT 時間シフト 電卓ランダムトーナメント表作成ツールランダム時刻ジェネレーター斜辺電卓オンライン句読点削除ツールランダムアニマルジェネレーターランダム国ジェネレーターホームランの打席電卓動画を回転比率電卓配当利回り電卓CRC32チェックサム電卓ビデオをループ再生マン・ホイットニーのU検定計算機HEXコンバーター変化率電卓ボルト締付トルク計算機土星回帰電卓階段電卓動画から画像抽出ツール🎮 ゲーム感度変換器筆算足し算・引き算計算機有効数字電卓BUN対クレアチニン比電卓太陽・月・上昇星座電卓 🌞🌙✨桁数電卓⚔️ DPS電卓不可視文字除去ツール論理ゲートシミュレーター三角関数グラフ作成ツール加速度電卓fena電卓平均電卓-高精度自然対数電卓表面積電卓ビデオ速度を調整双子素数ファインダー標準誤差電卓正多角形電卓文字数による改行ピタゴラスの定理電卓散布図作成ツール複数分数電卓TikTok収益計算ツールトルク電卓面積分電卓素数ですか10進数からBCDへのコンバーター四捨五入電卓馬力電卓平方数リストアナグラム生成器割引率電卓周波数波長変換ツールhba1c電卓VTTからtxtへのコンバーターコラッツ予想電卓分数電卓csvからsrtへじゃんけんジェネレーター年の日電卓 - 今日は今年の何日目確率分布電卓3d距離電卓カイ二乗検定電卓グレイコード・バイナリ変換電卓ノノグラムジェネレーター (ピクロス)階乗電卓筆算かけ算計算機円錐台電卓絶対値電卓HTMLからテキストコンバータカロリー赤字電卓ランダムピッカーランニングペース電卓ワイヤーゲージ電卓極限電卓画像回転ツール身長パーセンタイル電卓atan2電卓SRTからTXTへの変換ツールアークタンジェント電卓🖱️ クリックカウンターテキストからバイナリ/16進数/ASCII変換器ランダム整数ジェネレーター線積分計算機野球のバッティング平均電卓音節カウンターRC時定数電卓Twitch収益計算ツール慣性モーメント計算機行番号を追加CPM 電卓🔊 トーンジェネレーターLog Base 10 電卓ベーカーズパーセント電卓二乗平均平方根電卓平方和の計算連分数電卓配管流量電卓ニュートン法電卓二重積分電卓小文字生成器 ⁽ᶜᵒᵖʸ ⁿ ᵖᵃˢᵗᵉ⁾沸点計算ツールAIトークンカウンタータンジェント電卓パスワード強度テスター割り切れるテスト電卓四分位範囲電卓水泳ペース計算機血液型計算機ワードサーチパズルジェネレーターCohen's d 電卓ポンドからキログラム変換オーディオ スプリッター中国剰余定理電卓四分位電卓psiからkPaへのコンバーターパーセントから小数へのコンバーター乗算電卓円周率の最初のn桁半減期電卓多項式因数分解電卓数字抽出ツール比較分数電卓水星逆行カレンダー放物線電卓数秘術電卓FacebookユーザーID検索IPアドレスから16進数への変換SVG最適化ツール標準ドリンク計算ツールワインペアリング提案ツールクライミンググレード変換器自転車ギア比計算機釣り結び強度計算機ヨガポーズホールドタイマー水泳SWOLF電卓レースタイム予測計算機ボクシングパンチ力計算機ラグビー得点電卓クリケット・ランレート電卓サッカーxg期待ゴール電卓テニススコアトラッカーWellsスコア電卓 (DVT/PE)グラスゴー・コーマ・スケール計算機アプガースコア計算機FFMI 電卓クーパー12分間走計算ツール1マイルウォークテストロックポート電卓除脂肪体重から筋力計算炭水化物インスリン比計算機インスリン感受性係数計算機ヘブライ暦変換器ヒジュラ暦変換器旧暦変換ツール文化別年齢電卓どれくらい前計算機あと何日カウントダウン電卓日付パターンジェネレーター中間日計算機日付に営業日を追加営業日計算機単語頻度アナライザー文の長さばらつき分析ツールヘミングウェイ風リーダビリティエディタ発音IPA変換ツールヴィジュネル暗号ツールアトバッシュ暗号ツールROT13エンコーダー・デコーダーEXIFデータビューア・削除ツールピッグラテン翻訳機バックロニム ジェネレーター頭字語ジェネレーターパングラムチェッカーリポグラム チェッカー画像からSVGトレーサー画像からASCIIアートへの変換器JSONスキーマジェネレーターTypeScriptプレイグラウンドLessからCSSへのコンパイラーSCSSからCSSへのコンパイラーSVGからReact/JSXへの変換器クエリ文字列ビルダーURLパーサーUUID検証・デコーダーHTTPステータスコードリファレンスcURLコマンドビルダーシェルピンスキーの三角形ジェネレーター3D曲面プロッター極方程式プロッタージュリア集合生成器マンデルブロ集合エクスプローラーL-Systemフラクタルジェネレータードロネー三角形分割ジェネレーターボロノイ図ジェネレータースピログラフジェネレーターテッセレーションジェネレーターシックスシグマ工程能力計算機パレート図ジェネレーターNPSネットプロモータースコア計算機コホート維持率電卓解約率計算機顧客獲得コストCAC計算機顧客生涯価値CLV電卓コンバージョン率電卓A/Bテスト サンプルサイズ電卓A/Bテスト有意性電卓レンズの式計算機導線の磁場電卓電場計算機クーロンの法則電卓スネルの法則計算機角速度計算機求心力計算機振り子周期電卓ばね定数電卓ドップラー効果電卓ソルティノレシオ電卓トレイナー・レシオ電卓株式ベータ計算機インフレ連動米国債TIPS電卓住宅ローン リキャスト 電卓フォワードレート電卓債券デュレーション電卓 マコーレーと修正債券コンベクシティ電卓インデックス連動年金電卓変額年金電卓リバースモーゲージ電卓年金支払い計算機そろばんシミュレーターロシア農民式乗算ヴェーダ数学トリック電卓古代エジプト式乗算電卓ローマ数字計算ソルバー暗算トレーナー九九クイズ繰り上がりと繰り下がりビジュアライザー数の合成と分解生成ツール硬貨文章題ソルバー距離・速さ・時間の三角形電卓仕事算ソルバー混合問題ソルバー年齢文章題ソルバー列車出会い問題ソルバー水分補給計算機ペース カロリー電卓薬剤投与量計算機アルコールカロリー電卓ボディリコンポジション電卓ランダム討論トピックジェネレーターランダムな猫犬の名前ジェネレーターランダム聖句ジェネレーターランダム算数問題ジェネレーターランダム段落ジェネレーターランダム英文ジェネレーター砂利・砂・表土計算機鋼材重量電卓梁の電卓ドルから金への変換ツールオプション電卓株式分割電卓ESPP電卓請求書遅延手数料電卓フリーランス時給電卓リース対購入電卓高度なチップ割り勘電卓持ち物リストジェネレーター時差ぼけ電卓旅行予算電卓飛行距離電卓熱損失電卓発電コスト電卓水使用量電卓家電電気代計算機家庭エネルギー監査電卓太陽光ROI電卓太陽光パネル電卓堆肥cn比計算機芝生肥料電卓霜の日付電卓レイズドベッド用土電卓NPK肥料電卓種子発芽率電卓動画ビットレート電卓音楽キー移調ツール音楽BPMタッパー写真ファイルサイズ推定電卓メガピクセルから印刷サイズ計算機クロップファクター電卓露出トライアングル電卓車両牽引能力電卓カーリース計算機0–60とクォーターマイル電卓EV充電時間電卓EV航続距離計算機トーラス電卓不規則多角形面積電卓円錐曲線識別ツール双曲線電卓Twitter/X 文字数カウンターYouTubeコメントピッカーYouTubeタグ抽出ツールyoutubeサムネイルダウンローダーyoutube収益見積もりツールランダムRPGキャラクタージェネレーター