FindEulerianCycle
グラフ g のオイラー(Euler)閉路を求める.
FindEulerianCycle[g,k]
最高で k 個のオイラー閉路を求める.
FindEulerianCycle[{vw,…},…]
規則 vw を使ってグラフ g を指定する.
詳細
- オイラー閉路はすべての辺を厳密に1回通る閉路である.
- FindEulerianCycleはオイラー閉路からなる経路のリストを返す.
- FindEulerianCycleはオイラー閉路が存在しない場合にはリスト{}を返す.
- FindEulerianCycle[g]は FindEulerianCycle[g,1]に等しい.
- FindEulerianCycle[g,All]は,グラフ g 内のすべてのオイラー閉路を求める.
- FindEulerianCycleは,無向グラフ,有向グラフ,多重グラフに使うことができる.
予備知識
- FindEulerianCycleは,グラフ内の他と区別できる1つ以上のオイラー閉路(オイラー回路,オイラー路とも呼ばれる)を見付けようと試みる.閉路は,辺リストのリストとして,あるいは見付からない場合には{}として返される.オイラー閉路(閉路が特定の端点を持つ明示的な経路を使って識別される場合には,より正しくはオイラー回路と呼ばれる)は,最初と最後の辺が端点で繋がり,各辺が厳密に1度だけ現れるような,互いに区別の付く辺の連続する列である.オイラー閉路は,ゲノム配列を再構築したり,de Bruijn配列を構築したり,最適な学会のスケジューリングを求めたりするのに使える.
- FindEulerianCycle[g,k]は,k 個のオイラー閉路を求めようと試みる.オイラー閉路では,回数指定 k を省略する(その場合には1であるとみなされる)場合も,正の整数の場合も,あるいはAllになる場合もある.オイラー閉路は,単純な閉路である必要はない.つまり,(必ず単純であるハミルトン(Hamilton)閉路とは違って)閉路内で頂点が繰り返されてもよい.
- オイラー閉路を含むグラフはオイラーグラフと呼ばれる.ただし,「Euler」と「Eulerian」で使い分けて,つまり「Euler graph」ですべての頂点が偶次数であるグラフを指すとする場合もあるので注意が必要である.後者の定義は,連結した単純グラフは奇次数の頂点がない場合,かつその場合に限り,オイラー回路を持つというオイラーの正しい(彼自身によって証明されることはなかった)観察によるものである.オイラー閉路はこのため,ハミルトン(Hamiltonian)閉路よりも数学的に研究しやすい. 個のノードを持つ連結したオイラー(Euler)グラフの数は, 個のノードを持つ連結したオイラー(Eulerian)グラフの数と等しいが,非連結のグラフについては数が異なる.どの閉路もすべての辺を通らないという場合でも,各ノードで複数の非連結の閉路を持つ非連結グラフが存在するからである.
- EulerianGraphQは,グラフがオイラー(Eulerian)グラフであるかどうかを判断するのに使える.他の種類の閉路を見付けるための関数として,FindCycleとFindHamiltonianCycleがある.
例題
すべて開くすべて閉じるスコープ (8)
FindEulerianCycleは無向グラフに使うことができる:
FindEulerianCycleは非オイラーグラフに対しては空の結果を返す:
FindEulerianCycleは大きいグラフに使うことができる:
アプリケーション (7)
ケーニヒスベルクのプレーゲル河に架かる7つの橋を2度通らずすべて1度だけ通ってもとの場所に戻ることはできない:
奇点が2つあるので(多重辺を避けるために)新たな頂点を通して奇点を繋いで拡張したオイラーグラフを作ることができる:
頂点 を含む辺が最後になるまでオイラー閉路の辺を回転させる:
1人が連続する2つの会議の両方に出席できるような最適のスケジュールはない:
頂点が長さ(k-1)の部分配列で辺が長さ k の部分配列である,環状ゲノム"ATGGCGTGCA"のグラフに基づいたアセンブリ:
オイラー閉路から k 分木のde Bruijn系列を構築する:
特性と関係 (6)
オイラーグラフの大規模なコレクションを得るのにGraphDataを使う:
EulerianGraphQを使ってグラフにオイラー閉路があるかどうか調べる:
テキスト
Wolfram Research (2010), FindEulerianCycle, Wolfram言語関数, https://reference.wolfram.com/language/ref/FindEulerianCycle.html (2015年に更新).
CMS
Wolfram Language. 2010. "FindEulerianCycle." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2015. https://reference.wolfram.com/language/ref/FindEulerianCycle.html.
APA
Wolfram Language. (2010). FindEulerianCycle. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/FindEulerianCycle.html