mirror of
https://github.com/krahets/hello-algo.git
synced 2026-06-15 14:48:05 +08:00
30 lines
815 B
Go
30 lines
815 B
Go
// File: graph_bfs_test.go
|
||
// Created Time: 2023-02-18
|
||
// Author: Reanon (793584285@qq.com)
|
||
|
||
package chapter_graph
|
||
|
||
import (
|
||
"fmt"
|
||
"testing"
|
||
|
||
. "github.com/krahets/hello-algo/pkg"
|
||
)
|
||
|
||
func TestGraphBFS(t *testing.T) {
|
||
/* 無向グラフを初期化 */
|
||
vets := ValsToVets([]int{0, 1, 2, 3, 4, 5, 6, 7, 8, 9})
|
||
edges := [][]Vertex{
|
||
{vets[0], vets[1]}, {vets[0], vets[3]}, {vets[1], vets[2]}, {vets[1], vets[4]},
|
||
{vets[2], vets[5]}, {vets[3], vets[4]}, {vets[3], vets[6]}, {vets[4], vets[5]},
|
||
{vets[4], vets[7]}, {vets[5], vets[8]}, {vets[6], vets[7]}, {vets[7], vets[8]}}
|
||
graph := newGraphAdjList(edges)
|
||
fmt.Println("初期化後、グラフは:")
|
||
graph.print()
|
||
|
||
/* 幅優先探索 */
|
||
res := graphBFS(graph, vets[0])
|
||
fmt.Println("幅優先探索(BFS)の頂点列:")
|
||
PrintSlice(VetsToVals(res))
|
||
}
|