Scroll to navigation

__gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >(3cxx) __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >(3cxx)

NAME

__gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc > -

SYNOPSIS

Inherits __gnu_pbds::detail::left_child_next_sibling_heap< Value_Type, Cmp_Fn, _Alloc::size_type, _Alloc >.
Inherited by __gnu_pbds::detail::binomial_heap< Value_Type, Cmp_Fn, _Alloc >, and __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >.

Public Types


typedef _Alloc allocator_type
 
typedef Cmp_Fn cmp_fn
 
typedef base_type::const_iterator const_iterator
 
typedef __rebind_v::const_pointer const_pointer
 
typedef __rebind_v::const_reference const_reference
 
typedef _Alloc::difference_type difference_type
 
typedef base_type::iterator iterator
 
typedef
 
base_type::point_const_iterator point_const_iterator"
 
typedef base_type::point_iterator point_iterator
 
typedef __rebind_v::pointer pointer
 
typedef __rebind_v::reference reference
 
typedef _Alloc::size_type size_type
 
typedef Value_Type value_type
 

Public Member Functions


iterator begin ()
 
const_iterator begin () const
 
void clear ()
 
bool empty () const
 
iterator end ()
 
const_iterator end () const
 
void erase (point_iterator)
 
template<typename Pred > size_type erase_if (Pred)
 
Cmp_Fn & get_cmp_fn ()
 
const Cmp_Fn & get_cmp_fn () const
 
void join (binomial_heap_base< Value_Type, Cmp_Fn, _Alloc > &)
 
size_type max_size () const
 
void modify (point_iterator, const_reference)
 
void pop ()
 
point_iterator push (const_reference)
 
size_type size () const
 
template<typename Pred > void split (Pred, binomial_heap_base< Value_Type, Cmp_Fn, _Alloc > &)
 
void swap (left_child_next_sibling_heap< Value_Type, Cmp_Fn, _Alloc::size_type, _Alloc > &)
 
const_reference top () const
 

Protected Types


typedef base_type::node node
 
typedef _Alloc::template
 
rebind
 
< left_child_next_sibling_heap_node_
 
< Value_Type,
 
_Alloc::size_type, _Alloc >
 

>::other node_allocator"
 
typedef
 
base_type::node_const_pointer node_const_pointer"
 
typedef _Alloc::size_type node_metadata
 
typedef base_type::node_pointer node_pointer
 
typedef std::pair
 
< node_pointer, node_pointer > node_pointer_pair"
 

Protected Member Functions


binomial_heap_base (const Cmp_Fn &)
 
binomial_heap_base (const binomial_heap_base< Value_Type, Cmp_Fn, _Alloc > &)
 
void actual_erase_node (node_pointer)
 
void bubble_to_top (node_pointer)
 
void clear_imp (node_pointer)
 
template<typename It > void copy_from_range (It, It)
 
void find_max ()
 
node_pointer get_new_node_for_insert (const_reference)
 
node_pointer prune (Pred)
 
void swap (binomial_heap_base< Value_Type, Cmp_Fn, _Alloc > &)
 
void swap_with_parent (node_pointer, node_pointer)
 
void to_linked_list ()
 
void value_swap (left_child_next_sibling_heap &)
 

Static Protected Member Functions


static void make_child_of (node_pointer, node_pointer)
 
static node_pointer parent (node_pointer)
 

Protected Attributes


node_pointer m_p_max
 
node_pointer m_p_root
 
size_type m_size
 

Detailed Description

 

template<typename Value_Type, typename Cmp_Fn, typename _Alloc>class __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >

Base class for binomial heap.
Definition at line 77 of file binomial_heap_base_.hpp.
 

Author

Generated automatically by Doxygen for libstdc++ from the source code.
Sun Jan 6 2013 libstdc++