[解決済み] 反復的DFSと再帰的DFSの比較と要素の順序の違い
2022-03-07 18:18:28
質問
グラフを走査する再帰的DFSアルゴリズムを書きました。
void Graph<E, N>::DFS(Node n)
{
std::cout << ReadNode(n) << " ";
MarkVisited(n);
NodeList adjnodes = Adjacent(n);
NodeList::position pos = adjnodes.FirstPosition();
while(!adjnodes.End(pos))
{
Node adj = adjnodes.ReadList(pos);
if(!IsMarked(adj))
DFS(adj);
pos = adjnodes.NextPosition(pos);
}
}
そして、スタックを使った反復型DFSアルゴリズムを書きました。
template <typename E, typename N>
void Graph<E, N>::IterativeDFS(Node n)
{
Stack<Node> stack;
stack.Push(n);
while(!stack.IsEmpty())
{
Node u = stack.Read();
stack.Pop();
if(!IsMarked(u))
{
std::cout << ReadNode(u) << " ";
MarkVisited(u);
NodeList adjnodes = Adjacent(u);
NodeList::position pos = adjnodes.FirstPosition();
while(!adjnodes.End(pos))
{
stack.Push(adjnodes.ReadList(pos));
pos = adjnodes.NextPosition(pos);
}
}
}
私の問題は、例えば、3つのノード 'a', 'b', 'c' とアーク ('a', 'b') と ('a', 'c') を入力したグラフで、私の出力は次のようになります。
'a', 'b', 'c'を再帰的DFS版で、と。
a'、'c'、'b' は反復 DFS の方です。
どうしたら同じ順番になるのでしょうか?私のやり方が悪いのでしょうか?
ありがとうございました。
解決方法は?
どちらも有効 DFSのアルゴリズム。DFSは、どのノードが最初に見えるかを指定しない。エッジ間の順序は定義されないので、重要ではありません[エッジは通常集合であることを思い出してください]。違いは、各ノードの子をどのように扱うかによるものです。
では 繰り返しアプローチです。まず、すべての要素を挿入します。 をスタックに挿入し、次にスタックの先頭(最後に挿入されたノード)を処理します。 最初に処理するノードは、最後の子ノード .
で 再帰的アプローチ : 各ノードを見たときにそれを処理するのです。したがって 最初に扱うノードは、最初の子 .
反復型DFSが再帰型DFSと同じ結果になるようにするには、次のようにする必要があります。 スタックに逆順に要素を追加する [各ノードについて、その最後の子を最初に、その最初の子を最後に挿入する] 。
関連
-
[解決済み】Visual Studio 2015で「非標準の構文; '&'を使用してメンバーへのポインターを作成します」エラー
-
[解決済み】非静的メンバ関数への参照を呼び出す必要がある
-
[解決済み】C++ - 解放されるポインタが割り当てられていないエラー
-
[解決済み] [Solved] Error C1083: Cannot open include file: 'stdafx.h'
-
[解決済み】致命的なエラー LNK1169: ゲームプログラミングで1つ以上の多重定義されたシンボルが発見された
-
[解決済み】関数名の前に期待されるイニシャライザー
-
[解決済み] 既に.objで定義されている-二重包含はない
-
[解決済み】fpermissiveフラグは何をするのですか?
-
[解決済み】エラー:strcpyがこのスコープで宣言されていない
-
[解決済み】エラー。引数リストに一致するコンストラクタのインスタンスがない
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】Visual Studio 2015で「非標準の構文; '&'を使用してメンバーへのポインターを作成します」エラー
-
[解決済み】getline()が何らかの入力の後に使用されると動作しない 【重複あり
-
[解決済み] string does not name a type Errorが発生するのはなぜですか?
-
[解決済み】変数 '' を抽象型 '' と宣言できない。
-
[解決済み】Cygwin Make bash コマンドが見つかりません。
-
[解決済み] クラスにデフォルトコンストラクタが存在しない。
-
[解決済み】Visual C++で "Debug Assertion failed "の原因となる行を見つける。
-
[解決済み】C++ - 適切なデフォルトコンストラクタがない [重複]。
-
[解決済み】デバッグアサーションに失敗しました
-
[解決済み] 警告:暗黙の定数変換でのオーバーフロー