use crate::algo::graph::AdjacencyList;
impl AdjacencyList {
pub fn dfs(&self, start: usize) -> usize {
let mut count = 0;
let mut visited = vec![false; self.len()];
let mut stack = Vec::new();
stack.push(start);
visited[start] = true;
while let Some(node) = stack.pop() {
count += 1;
let neighbours = &self[node];
for &edge in neighbours {
if !visited[edge.to] {
stack.push(edge.to);
visited[edge.to] = true;
}
}
}
count
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_dfs_iterative() {
const N: usize = 5;
let mut graph = AdjacencyList::with_size(N);
graph.add_directed_edge(0, 1, 4);
graph.add_directed_edge(0, 2, 5);
graph.add_directed_edge(1, 2, -2);
graph.add_directed_edge(1, 3, 6);
graph.add_directed_edge(2, 3, 1);
graph.add_directed_edge(2, 2, 10);
let count = graph.dfs(0);
assert_eq!(count, 4);
println!("DFS node count starting at node 0: {}", count);
let count = graph.dfs(4);
assert_eq!(count, 1);
println!("DFS node count starting at node 4: {}", count);
}
}
use crate::algo::graph::UnweightedAdjacencyList;
impl UnweightedAdjacencyList {
pub fn dfs(&self, start: usize) -> usize {
let mut count = 0;
let mut visited = vec![false; self.len()];
let mut stack = Vec::new();
stack.push(start);
visited[start] = true;
while let Some(node) = stack.pop() {
count += 1;
let neighbours = &self[node];
for &edge in neighbours {
if !visited[edge] {
stack.push(edge);
visited[edge] = true;
}
}
}
count
}
}