phash.ph: yet another attempt at getting Perl to behave, arithmetically
[nasm/avx512.git] / perllib / Graph / Traversal / BFS.pm
blob2678f72e75b5160c9bbdc06ea694dd5754f5e695
1 package Graph::Traversal::BFS;
3 use strict;
5 use Graph::Traversal;
6 use base 'Graph::Traversal';
8 sub current {
9 my $self = shift;
10 $self->{ order }->[ 0 ];
13 sub see {
14 my $self = shift;
15 shift @{ $self->{ order } };
18 *bfs = \&Graph::Traversal::postorder;
21 __END__
22 =pod
24 =head1 NAME
26 Graph::Traversal::BFS - breadth-first traversal of graphs
28 =head1 SYNOPSIS
30 use Graph;
31 my $g = Graph->new;
32 $g->add_edge(...);
33 use Graph::Traversal::BFS;
34 my $b = Graph::Traversal::BFS->new(%opt);
35 $b->bfs; # Do the traversal.
37 =head1 DESCRIPTION
39 With this class one can traverse a Graph in breadth-first order.
41 The callback parameters %opt are explained in L<Graph::Traversal>.
43 =head2 Methods
45 The following methods are available:
47 =over 4
49 =item dfs
51 Traverse the graph in depth-first order.
53 =back
55 =head1 SEE ALSO
57 L<Graph::Traversal>, L<Graph::Traversal::DFS>, L<Graph>.
59 =cut