libstdc++
__gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc > Class Template Reference

#include <rc_binomial_heap_.hpp>

Inheritance diagram for __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >:
[legend]

Public Types

typedef base_type::allocator_type allocator_type
 
typedef base_type::cmp_fn cmp_fn
 
typedef base_type::const_iterator const_iterator
 
typedef base_type::const_pointer const_pointer
 
typedef base_type::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 base_type::pointer pointer
 
typedef base_type::reference reference
 
typedef _Alloc::size_type size_type
 
typedef Value_Type value_type
 

Public Member Functions

 rc_binomial_heap (const binomial_heap_base< Value_Type, Cmp_Fn, _Alloc > &)
 
 rc_binomial_heap (const Cmp_Fn &)
 
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 (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_traits::allocator_type node_allocator
 
typedef _Alloc::size_type node_metadata
 
typedef std::pair< node_pointer, node_pointer > node_pointer_pair
 

Protected Member Functions

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_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::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >

Redundant-counter binomial heap.

Definition at line 66 of file rc_binomial_heap_.hpp.

Member Typedef Documentation

◆ allocator_type

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::allocator_type __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::allocator_type

Definition at line 89 of file rc_binomial_heap_.hpp.

◆ cmp_fn

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::cmp_fn __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::cmp_fn

Definition at line 88 of file rc_binomial_heap_.hpp.

◆ const_iterator

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::const_iterator __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::const_iterator

Definition at line 86 of file rc_binomial_heap_.hpp.

◆ const_pointer

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::const_pointer __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::const_pointer

Definition at line 81 of file rc_binomial_heap_.hpp.

◆ const_reference

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::const_reference __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::const_reference

Definition at line 83 of file rc_binomial_heap_.hpp.

◆ difference_type

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef _Alloc::difference_type __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::difference_type

Definition at line 79 of file rc_binomial_heap_.hpp.

◆ iterator

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::iterator __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::iterator

Definition at line 87 of file rc_binomial_heap_.hpp.

◆ node

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
protectedinherited

Definition at line 85 of file binomial_heap_base_.hpp.

◆ node_allocator

typedef alloc_traits::allocator_type __gnu_pbds::detail::left_child_next_sibling_heap< Value_Type, Cmp_Fn, _Alloc::size_type , _Alloc >::node_allocator
protectedinherited

Definition at line 101 of file left_child_next_sibling_heap_.hpp.

◆ node_metadata

typedef _Alloc::size_type __gnu_pbds::detail::left_child_next_sibling_heap< Value_Type, Cmp_Fn, _Alloc::size_type , _Alloc >::node_metadata
protectedinherited

Definition at line 105 of file left_child_next_sibling_heap_.hpp.

◆ node_pointer_pair

typedef std::pair<node_pointer, node_pointer> __gnu_pbds::detail::left_child_next_sibling_heap< Value_Type, Cmp_Fn, _Alloc::size_type , _Alloc >::node_pointer_pair
protectedinherited

Definition at line 106 of file left_child_next_sibling_heap_.hpp.

◆ point_const_iterator

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::point_const_iterator __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::point_const_iterator

Definition at line 84 of file rc_binomial_heap_.hpp.

◆ point_iterator

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::point_iterator __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::point_iterator

Definition at line 85 of file rc_binomial_heap_.hpp.

◆ pointer

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::pointer __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::pointer

Definition at line 80 of file rc_binomial_heap_.hpp.

◆ reference

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef base_type::reference __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::reference

Definition at line 82 of file rc_binomial_heap_.hpp.

◆ size_type

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef _Alloc::size_type __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::size_type

Definition at line 78 of file rc_binomial_heap_.hpp.

◆ value_type

template<typename Value_Type , typename Cmp_Fn , typename _Alloc >
typedef Value_Type __gnu_pbds::detail::rc_binomial_heap< Value_Type, Cmp_Fn, _Alloc >::value_type

Definition at line 77 of file rc_binomial_heap_.hpp.

Member Data Documentation

◆ m_p_max

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
protectedinherited

Definition at line 186 of file binomial_heap_base_.hpp.

◆ m_p_root

node_pointer __gnu_pbds::detail::left_child_next_sibling_heap< Value_Type, Cmp_Fn, _Alloc::size_type , _Alloc >::m_p_root
protectedinherited

Definition at line 270 of file left_child_next_sibling_heap_.hpp.

◆ m_size

size_type __gnu_pbds::detail::left_child_next_sibling_heap< Value_Type, Cmp_Fn, _Alloc::size_type , _Alloc >::m_size
protectedinherited

Definition at line 271 of file left_child_next_sibling_heap_.hpp.


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