From 1943ea3c60c3f4a46e74d150ca2dcf9c2a8b2ae5 Mon Sep 17 00:00:00 2001 From: Andre Alves Date: Mon, 24 Oct 2022 20:38:13 -0300 Subject: [PATCH] add: DFS non recursive algorithm --- DIRECTORY.md | 3 ++ Graphs/DepthFirstSearch.php | 35 +++++++++++++++++++ tests/Graphs/DepthFirstSearchTest.php | 48 +++++++++++++++++++++++++++ 3 files changed, 86 insertions(+) create mode 100644 Graphs/DepthFirstSearch.php create mode 100644 tests/Graphs/DepthFirstSearchTest.php diff --git a/DIRECTORY.md b/DIRECTORY.md index 1ac3968..edd3260 100644 --- a/DIRECTORY.md +++ b/DIRECTORY.md @@ -13,6 +13,9 @@ * [Octaltodecimal](./Conversions/OctalToDecimal.php) * [Speedconversion](./Conversions/SpeedConversion.php) +## Graphs + * [DeothFirstSearch](./Graphs/DepthFirstSearch.php) + ## Maths * [Absolutemax](./Maths/AbsoluteMax.php) * [Absolutemin](./Maths/AbsoluteMin.php) diff --git a/Graphs/DepthFirstSearch.php b/Graphs/DepthFirstSearch.php new file mode 100644 index 0000000..936484c --- /dev/null +++ b/Graphs/DepthFirstSearch.php @@ -0,0 +1,35 @@ + ["B", "C", "D"], + "B" => ["A", "D", "E"], + "C" => ["A", "F"], + "D" => ["B", "D"], + "E" => ["B", "F"], + "F" => ["C", "E", "G"], + "G" => ["F"], + ); + $visited = dfs($graph, "A"); + $this->assertEquals(["A", "B", "D", "E", "F", "C", "G"], $visited); + } + public function testDepthFirstSearch2() + { + $graph = array( + [1, 2], + [2], + [0, 3], + [3], + ); + + $visited = dfs($graph, 2); + $this->assertEquals([2, 0, 1, 3], $visited); + } + public function testDepthFirstSearch3() + { + $graph = array( + [2, 3, 1], + [0], + [0, 4], + [0], + [2], + ); + $visited = dfs($graph, 0); + $this->assertEquals([0, 2, 4, 3, 1], $visited); + } +}