Heap::Elem::NumRev - Reversed Numeric Heap Elements


Heap documentation Contained in the Heap distribution.

Index


Code Index:

NAME

Top

Heap::Elem::NumRev - Reversed Numeric Heap Elements

SYNOPSIS

Top

  use Heap::Elem::NumRev( NumRElem );
  use Heap::Fibonacci;

  my $heap = Heap::Fibonacci->new;
  my $elem;

  foreach $i ( 1..100 ) {
      $elem = NumRElem( $i );
      $heap->add( $elem );
  }

  while( defined( $elem = $heap->extract_top ) ) {
      print "Largest is ", $elem->val, "\n";
  }

DESCRIPTION

Top

Heap::Elem::NumRev is used to wrap numeric values into an element that can be managed on a heap. The top of the heap will have the largest element still remaining. (See Heap::Elem::Num if you want the heap to always return the smallest element.)

The details of the Elem interface are described in Heap::Elem.

The details of using a Heap interface are described in Heap.

AUTHOR

Top

John Macdonald, john@perlwolf.com

COPYRIGHT

Top

SEE ALSO

Top

Heap(3), Heap::Elem(3), Heap::Elem::Num(3).


Heap documentation Contained in the Heap distribution.

package Heap::Elem::NumRev;

use strict;
use vars qw($VERSION @ISA @EXPORT @EXPORT_OK);
use Heap::Elem;

require Exporter;

@ISA = qw(Exporter Heap::Elem);

# No names exported.
@EXPORT = ( );

# Available for export: NumRElem (to allocate a new Heap::Elem::NumRev value)
@EXPORT_OK = qw( NumRElem );

$VERSION = '0.80';

sub NumRElem {	# exportable synonym for new
    Heap::Elem::NumRev->new(@_);
}

# compare two NumR elems (reverse order)
sub cmp {
    return $_[1][0] <=> $_[0][0];
}

1;
__END__