STLdoc
STLdocumentation
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Public Types | Public Member Functions | Protected Types | Protected Member Functions | Protected Attributes | Private Types | Private Member Functions | List of all members
__gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc > Class Template Reference

Base class for binomial heap. More...

#include <ext/pb_ds/detail/binomial_heap_base_/binomial_heap_base_.hpp>

Inheritance diagram for __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >:
__gnu_pbds::detail::binomial_heap< Value_Type, Cmp_Fn, _Alloc > __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >

Public Types

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

Public Member Functions

point_iterator push (const_reference)
 
void modify (point_iterator, const_reference)
 
const_reference top () const
 
void pop ()
 
void erase (point_iterator)
 
void clear ()
 
template<typename Pred >
size_type erase_if (Pred)
 
template<typename Pred >
void split (Pred, PB_DS_CLASS_C_DEC &)
 
void join (PB_DS_CLASS_C_DEC &)
 

Protected Types

typedef base_type::node node
 
typedef base_type::node_pointer node_pointer
 
typedef
base_type::node_const_pointer 
node_const_pointer
 

Protected Member Functions

 binomial_heap_base ()
 
 binomial_heap_base (const Cmp_Fn &)
 
 binomial_heap_base (const PB_DS_CLASS_C_DEC &)
 
void swap (PB_DS_CLASS_C_DEC &)
 
 ~binomial_heap_base ()
 
template<typename It >
void copy_from_range (It, It)
 
void find_max ()
 

Protected Attributes

node_pointer m_p_max
 

Private Types

typedef _Alloc::template
rebind< Value_Type >::other 
__rebind_v
 
typedef PB_DS_B_HEAP_BASE base_type
 

Private Member Functions

node_pointer fix (node_pointer) const
 
void insert_node (node_pointer)
 
void remove_parentless_node (node_pointer)
 
node_pointer join (node_pointer, node_pointer) const
 

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.

Member Typedef Documentation

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef _Alloc::template rebind<Value_Type>::other __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::__rebind_v
private
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef _Alloc __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::allocator_type
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef PB_DS_B_HEAP_BASE __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::base_type
private
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef Cmp_Fn __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::cmp_fn
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::const_iterator __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::const_iterator
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef __rebind_v::const_pointer __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::const_pointer
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef __rebind_v::const_reference __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::const_reference
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef _Alloc::difference_type __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::difference_type
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::iterator __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::iterator
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::node __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::node
protected
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::node_const_pointer __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::node_const_pointer
protected
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::node_pointer __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::node_pointer
protected
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::point_const_iterator __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::point_const_iterator
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::point_iterator __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::point_iterator
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef __rebind_v::pointer __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::pointer
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef __rebind_v::reference __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::reference
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef _Alloc::size_type __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::size_type
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef Value_Type __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::value_type

Constructor & Destructor Documentation

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
__gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::binomial_heap_base ( )
protected
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
__gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::binomial_heap_base ( const Cmp_Fn &  )
protected
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
__gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::binomial_heap_base ( const PB_DS_CLASS_C_DEC )
protected
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
__gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::~binomial_heap_base ( )
protected

Member Function Documentation

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::clear ( )
inline
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
template<typename It >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::copy_from_range ( It  ,
It   
)
protected
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::erase ( point_iterator  )
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
template<typename Pred >
size_type __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::erase_if ( Pred  )
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::find_max ( )
inlineprotected
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
node_pointer __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::fix ( node_pointer  ) const
inlineprivate
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::insert_node ( node_pointer  )
inlineprivate
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::join ( PB_DS_CLASS_C_DEC )
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
node_pointer __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::join ( node_pointer  ,
node_pointer   
) const
inlineprivate
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::modify ( point_iterator  ,
const_reference   
)
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::pop ( )
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
point_iterator __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::push ( const_reference  )
inline
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::remove_parentless_node ( node_pointer  )
inlineprivate
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
template<typename Pred >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::split ( Pred  ,
PB_DS_CLASS_C_DEC  
)
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
void __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::swap ( PB_DS_CLASS_C_DEC )
protected
template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
const_reference __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::top ( ) const
inline

Member Data Documentation

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
node_pointer __gnu_pbds::detail::binomial_heap_base< Value_Type, Cmp_Fn, _Alloc >::m_p_max
protected

The documentation for this class was generated from the following file: