Represent an undirected graph as a per-vertex list of neighbours. For every edge (u, v), append v to adj[u] and u to adj[v]. Neighbour lists keep insertion order so the graph is a stable, deterministic fixture for the search lessons.

Algorithm

The canonical fixture is 6 vertices [1..6] with undirected edges (1,2), (1,3), (2,4), (3,4), (4,5), (5,6) inserted in that order. The final adjacency list is {1: [2, 3], 2: [1, 4], 3: [1, 4], 4: [2, 3, 5], 5: [4, 6], 6: [5]}. This same graph drives graph-bfs, graph-dfs, and graph-shortest-path-bfs.

Basic Implementation

basic.sh
#!/usr/bin/env bash
set -euo pipefail
edges=("1 2" "1 3" "2 4" "3 4" "4 5" "5 6")
declare -A adj
for e in "${edges[@]}"; do
	read -r u v <<< "$e"
	adj[$u]="${adj[$u]:-} $v"
	adj[$v]="${adj[$v]:-} $u"
done
printf '{'
sep=''
for v in 1 2 3 4 5 6; do
	read -ra nbrs <<< "${adj[$v]}"
	printf '%s%d: [' "$sep" "$v"
	isep=''
	for nb in "${nbrs[@]}"; do
		printf '%s%d' "$isep" "$nb"
		isep=', '
	done
	printf ']'
	sep=', '
done
printf '}\n'

Complexity

  • Build: O(V + E)
  • Space: O(V + E)

Implementation notes

  • Bash: an associative array maps each vertex to a space-separated neighbour string; vertices 1..6 are iterated for stable output.
  • The replay shows the adjacency list after each edge is added, matching the lesson spec.
adjacency list Each edge adds two directed entries, one in each direction.