📄 storage_sparse.hpp
字号:
typedef std::ptrdiff_t difference_type;
typedef I index_type;
typedef I value_type;
typedef const I &const_reference;
typedef I &reference;
typedef const I *const_pointer;
typedef I *pointer;
// Construction and destruction
BOOST_UBLAS_INLINE
set_array ():
capacity_ (0), data_ (new value_type [0]), size_ (0) {
// Assuming std compliant allocator as requested during review.
// if (! data_)
// throw std::bad_alloc ();
std::fill (data_, data_ + size_, value_type ());
}
BOOST_UBLAS_INLINE
set_array (no_init):
capacity_ (0), data_ (new value_type [0]), size_ (0) {
// Assuming std compliant allocator as requested during review.
// if (! data_)
// throw std::bad_alloc ();
}
BOOST_UBLAS_EXPLICIT BOOST_UBLAS_INLINE
set_array (size_type size):
capacity_ (size), data_ (new value_type [size]), size_ (0) {
// Assuming std compliant allocator as requested during review.
// if (! data_)
// throw std::bad_alloc ();
std::fill (data_, data_ + size_, value_type ());
}
BOOST_UBLAS_EXPLICIT BOOST_UBLAS_INLINE
set_array (size_type size, no_init):
capacity_ (size), data_ (new value_type [size]), size_ (0) {
// Assuming std compliant allocator as requested during review.
// if (! data_)
// throw std::bad_alloc ();
}
BOOST_UBLAS_INLINE
set_array (const set_array &a):
capacity_ (a.size_), data_ (new value_type [a.size_]), size_ (a.size_) {
// Assuming std compliant allocator as requested during review.
// if (! data_)
// throw std::bad_alloc ();
*this = a;
}
BOOST_UBLAS_INLINE
~set_array () {
// Assuming std compliant allocator as requested during review.
// if (! data_)
// throw std::bad_alloc ();
delete [] data_;
}
// Resizing
BOOST_UBLAS_INLINE
void resize (size_type size) {
BOOST_UBLAS_CHECK (size_ <= capacity_, internal_logic ());
if (size > capacity_) {
pointer data = new value_type [size << 1];
// Assuming std compliant allocator as requested during review.
// if (! data)
// throw std::bad_alloc ();
// if (! data_)
// throw std::bad_alloc ();
std::copy (data_, data_ + std::min (size, size_), data);
std::fill (data + std::min (size, size_), data + size, value_type ());
delete [] data_;
capacity_ = size << 1;
data_ = data;
}
size_ = size;
BOOST_UBLAS_CHECK (size_ <= capacity_, internal_logic ());
}
// Reserving
BOOST_UBLAS_INLINE
void reserve (size_type capacity) {
BOOST_UBLAS_CHECK (size_ <= capacity_, internal_logic ());
if (capacity > capacity_) {
pointer data = new value_type [capacity];
// Assuming std compliant allocator as requested during review.
// if (! data)
// throw std::bad_alloc ();
// if (! data_)
// throw std::bad_alloc ();
std::copy (data_, data_ + size_, data);
delete [] data_;
capacity_ = capacity;
data_ = data;
}
BOOST_UBLAS_CHECK (size_ <= capacity_, internal_logic ());
}
BOOST_UBLAS_INLINE
size_type size () const {
return size_;
}
// Element access
BOOST_UBLAS_INLINE
const_reference operator [] (index_type i) {
pointer it = find (i);
if (it == end ())
it = insert (end (), i);
BOOST_UBLAS_CHECK (it != end (), internal_logic ());
return *it;
}
// Assignment
BOOST_UBLAS_INLINE
set_array &operator = (const set_array &a) {
// Too unusual semantic.
// Thanks to Michael Stevens for spotting this.
// BOOST_UBLAS_CHECK (this != &a, external_logic ());
if (this != &a) {
resize (a.size_);
std::copy (a.data_, a.data_ + a.size_, data_);
}
return *this;
}
BOOST_UBLAS_INLINE
set_array &assign_temporary (set_array &a) {
swap (a);
return *this;
}
// Swapping
BOOST_UBLAS_INLINE
void swap (set_array &a) {
// Too unusual semantic.
// BOOST_UBLAS_CHECK (this != &a, external_logic ());
if (this != &a) {
std::swap (capacity_, a.capacity_);
std::swap (data_, a.data_);
std::swap (size_, a.size_);
}
}
#ifndef BOOST_UBLAS_NO_MEMBER_FRIENDS
BOOST_UBLAS_INLINE
friend void swap (set_array &a1, set_array &a2) {
a1.swap (a2);
}
#endif
// Element insertion and deletion
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
pointer push_back (pointer it, const value_type &p) {
if (size () == 0 || (*(it = end () - 1)) < p) {
resize (size () + 1);
*(it = end () - 1) = p;
return it;
}
// Raising exceptions abstracted as requested during review.
// throw external_logic ();
external_logic ().raise ();
return it;
}
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
pointer insert (pointer it, const value_type &p) {
it = detail::lower_bound (begin (), end (), p, std::less<value_type> ());
difference_type n = it - begin ();
BOOST_UBLAS_CHECK (size () == 0 || size () == size_type (n) || *it != p, external_logic ());
resize (size () + 1);
it = begin () + n;
std::copy_backward (it, end () - 1, end ());
*it = p;
return it;
}
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
void insert (pointer it, pointer it1, pointer it2) {
#ifdef BOOST_UBLAS_BOUNDS_CHECK
while (it1 != it2) {
insert (it, *it1);
++ it1;
}
#else
difference_type n = it - begin ();
resize (size () + it2 - it1);
it = begin () + n;
std::copy (it1, it2, it);
std::sort (begin (), end (), std::less<value_type> ());
#endif
}
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
void erase (pointer it) {
BOOST_UBLAS_CHECK (begin () <= it && it < end (), bad_index ());
std::copy (it + 1, end (), it);
resize (size () - 1);
}
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
void erase (pointer it1, pointer it2) {
BOOST_UBLAS_CHECK (begin () <= it1 && it1 < it2 && it2 <= end (), bad_index ());
std::copy (it2, end (), it1);
resize (size () - (it2 - it1));
}
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
void clear () {
resize (0);
}
// Element lookup
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
const_pointer find (index_type i) const {
#ifdef BOOST_UBLAS_DEPRECATED
std::pair<const_pointer, const_pointer> pit;
pit = std::equal_range (begin (), end (), i, std::less<value_type> ());
if (*pit.first == i)
return pit.first;
else if (*pit.second == i)
return pit.second;
else
return end ();
#else
const_pointer it (detail::lower_bound (begin (), end (), i, std::less<value_type> ()));
if (it == end () || *it != i)
it = end ();
return it;
#endif
}
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
pointer find (index_type i) {
#ifdef BOOST_UBLAS_DEPRECATED
std::pair<pointer, pointer> pit;
pit = std::equal_range (begin (), end (), i, std::less<value_type> ());
if (*pit.first == i)
return pit.first;
else if (*pit.second == i)
return pit.second;
else
return end ();
#else
pointer it (detail::lower_bound (begin (), end (), i, std::less<value_type> ()));
if (it == end () || *it != i)
it = end ();
return it;
#endif
}
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
const_pointer lower_bound (index_type i) const {
return detail::lower_bound (begin (), end (), i, std::less<value_type> ());
}
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
pointer lower_bound (index_type i) {
return detail::lower_bound (begin (), end (), i, std::less<value_type> ());
}
#ifdef BOOST_UBLAS_DEPRECATED
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
const_pointer upper_bound (index_type i) const {
return detail::upper_bound (begin (), end (), i, std::less<value_type> ());
}
// This function seems to be big. So we do not let the compiler inline it.
// BOOST_UBLAS_INLINE
pointer upper_bound (index_type i) {
return detail::upper_bound (begin (), end (), i, std::less<value_type> ());
}
#endif
// Iterators simply are pointers.
typedef const_pointer const_iterator;
BOOST_UBLAS_INLINE
const_iterator begin () const {
return data_;
}
BOOST_UBLAS_INLINE
const_iterator end () const {
return data_ + size_;
}
typedef pointer iterator;
BOOST_UBLAS_INLINE
iterator begin () {
return data_;
}
BOOST_UBLAS_INLINE
iterator end () {
return data_ + size_;
}
// Reverse iterators
#ifdef BOOST_MSVC_STD_ITERATOR
typedef std::reverse_iterator<const_iterator, value_type, const_reference> const_reverse_iterator;
#else
typedef std::reverse_iterator<const_iterator> const_reverse_iterator;
#endif
BOOST_UBLAS_INLINE
const_reverse_iterator rbegin () const {
return const_reverse_iterator (end ());
}
BOOST_UBLAS_INLINE
const_reverse_iterator rend () const {
return const_reverse_iterator (begin ());
}
#ifdef BOOST_MSVC_STD_ITERATOR
typedef std::reverse_iterator<iterator, value_type, reference> reverse_iterator;
#else
typedef std::reverse_iterator<iterator> reverse_iterator;
#endif
BOOST_UBLAS_INLINE
reverse_iterator rbegin () {
return reverse_iterator (end ());
}
BOOST_UBLAS_INLINE
reverse_iterator rend () {
return reverse_iterator (begin ());
}
private:
size_type capacity_;
pointer data_;
size_type size_;
};
// This specialization is missing in Dinkumware's STL?!
template<class I, class F>
BOOST_UBLAS_INLINE
void swap (std::set<I, F> &a1, std::set<I, F> &a2) {
// Too unusual semantic.
// BOOST_UBLAS_CHECK (&a1 != &a2, external_logic ());
if (&a1 != &a2)
a1.swap (a2);
}
}}}
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -