Files
Yudong Jin 772183705e Add ru version (#1865)
* Add Russian docs site baseline

* Add Russian localized codebase

* Polish Russian code wording

* Update ru code translation.

* Update code translation and chapter covers.

* Fix pythontutor extraction.

* Add README and landing page.

* placeholder of profiles

* Use figures of English version

* Remove chapter paperbook
2026-03-28 04:24:07 +08:00

37 lines
1.5 KiB
Go

// File: graph_dfs.go
// Created Time: 2023-02-18
// Author: Reanon (793584285@qq.com)
package chapter_graph
import (
. "github.com/krahets/hello-algo/pkg"
)
/* Вспомогательная функция обхода в глубину */
func dfs(g *graphAdjList, visited map[Vertex]struct{}, res *[]Vertex, vet Vertex) {
// Операция append возвращает новую ссылку, поэтому исходную ссылку нужно заново присвоить новому срезу
*res = append(*res, vet)
visited[vet] = struct{}{}
// Обойти все смежные вершины данной вершины
for _, adjVet := range g.adjList[vet] {
_, isExist := visited[adjVet]
// Рекурсивно обходить смежные вершины
if !isExist {
dfs(g, visited, res, adjVet)
}
}
}
/* Обход в глубину */
// Использовать список смежности для представления графа, чтобы получить все смежные вершины заданной вершины
func graphDFS(g *graphAdjList, startVet Vertex) []Vertex {
// Последовательность обхода вершин
res := make([]Vertex, 0)
// Хеш-множество для хранения уже посещенных вершин
visited := make(map[Vertex]struct{})
dfs(g, visited, &res, startVet)
// Вернуть последовательность обхода вершин
return res
}