亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? stl_bvector.h

?? 粗慥集成算法集合 ,并有詳細的文檔資料和測試數據處
?? H
?? 第 1 頁 / 共 3 頁
字號:
  void _Init_bounds() {
    _M_iter_list._Orphan(_M_start);
    _M_iter_list._Orphan(_M_finish);
  }
  void _Invalidate_iterator(const _Bit_iterator& __it) { 
    __invalidate_iterator(&_M_iter_list,__it);
  }
  void _Invalidate_all() {
    _M_iter_list._Invalidate_all();
  }
# endif
};


// The next few lines are confusing.  What we're doing is declaring a
//  partial specialization of vector<T, Alloc> if we have the necessary
//  compiler support.  Otherwise, we define a class bit_vector which uses
//  the default allocator. 

#if defined(__STL_CLASS_PARTIAL_SPECIALIZATION) \
 && !defined(__STL_PARTIAL_SPECIALIZATION_BUG) && ! defined(__STL_NO_BOOL)
# define __SGI_STL_VECBOOL_TEMPLATE
# define __BVEC_TMPL_HEADER template <class _Alloc>
#else
# undef __SGI_STL_VECBOOL_TEMPLATE
# ifdef __STL_NO_BOOL
#  define __BVEC_TMPL_HEADER
# else
#  define __BVEC_TMPL_HEADER __STL_TEMPLATE_NULL
# endif
# define _Alloc __STL_DEFAULT_ALLOCATOR(bool)
#endif

#ifdef __STL_NO_BOOL
# define __BVECTOR_QUALIFIED bit_vector
# define __BVECTOR           bit_vector
#else
# ifdef __SGI_STL_VECBOOL_TEMPLATE
#  define __BVECTOR_QUALIFIED vector<bool, _Alloc>
# else
#  define __BVECTOR_QUALIFIED vector<bool>
# endif
#ifdef __STL_PARTIAL_SPEC_NEEDS_TEMPLATE_ARGS
# define __BVECTOR __BVECTOR_QUALIFIED
#else
# define __BVECTOR vector
#endif
#endif


__BVEC_TMPL_HEADER
class __BVECTOR_QUALIFIED : public _Bvector_base<_Alloc >
{
  typedef _Bvector_base<_Alloc > _Base;
  typedef __BVECTOR_QUALIFIED _Self;
public:
  typedef bool value_type;
  typedef size_t size_type;
  typedef ptrdiff_t difference_type; 
  typedef _Bit_reference reference;
  typedef bool const_reference;
  typedef _Bit_reference* pointer;
  typedef const bool* const_pointer;

  typedef _Bit_iterator                iterator;
  typedef _Bit_const_iterator          const_iterator;

#if defined ( __STL_CLASS_PARTIAL_SPECIALIZATION ) && \
  ! defined (__STL_PARTIAL_SPECIALIZATION_BUG)
  typedef __STLPORT_STD::reverse_iterator<const_iterator> const_reverse_iterator;
  typedef __STLPORT_STD::reverse_iterator<iterator> reverse_iterator;
#else /* __STL_CLASS_PARTIAL_SPECIALIZATION */
# if defined (__STL_MSVC50_COMPATIBILITY)
  typedef __STLPORT_STD::reverse_iterator<const_iterator, value_type, const_reference, 
  const_pointer, difference_type> const_reverse_iterator;
  typedef __STLPORT_STD::reverse_iterator<iterator, value_type, reference, reference*, 
  difference_type> reverse_iterator;
# else
  typedef __STLPORT_STD::reverse_iterator<const_iterator, value_type, const_reference, 
                                  difference_type> const_reverse_iterator;
  typedef __STLPORT_STD::reverse_iterator<iterator, value_type, reference, difference_type>
          reverse_iterator;
# endif
#endif /* __STL_CLASS_PARTIAL_SPECIALIZATION */

# ifdef __SGI_STL_VECBOOL_TEMPLATE
  typedef typename _Base::allocator_type allocator_type;
# else
  typedef _Base::allocator_type allocator_type;
# endif

#if defined( __STL_HAS_NAMESPACES )
  __STL_USING_BASE_MEMBER _Bvector_base<_Alloc >::get_allocator;
protected:
  __STL_USING_BASE_MEMBER _Bvector_base<_Alloc >::_M_bit_alloc;
  __STL_USING_BASE_MEMBER _Bvector_base<_Alloc >::_M_deallocate;
  __STL_USING_BASE_MEMBER _Bvector_base<_Alloc >::_M_start;
  __STL_USING_BASE_MEMBER _Bvector_base<_Alloc >::_M_finish;
  __STL_USING_BASE_MEMBER _Bvector_base<_Alloc >::_M_end_of_storage;
# ifdef __STL_DEBUG
  __STL_USING_BASE_MEMBER _Bvector_base<_Alloc >::_M_iter_list;
# endif
#endif /* __STL_HAS_NAMESPACES */

protected:
# if defined (__STL_DEBUG)
# define _Make_iterator(__x,__y,__z) iterator(&_M_iter_list,__x,__y,__z)
# define _Make_const_iterator(__x,__y,__z) const_iterator(&_M_iter_list,__x,__y,__z)
# else
# define _Make_iterator(__x,__y,__z) iterator(__x,__y)
# define _Make_const_iterator(__x,__y,__z) const_iterator(__x,__y)
# endif

  void _M_initialize(size_type __n) {
    unsigned int* __q = _M_bit_alloc(__n);
    _M_end_of_storage._M_data = __q + (__n + __WORD_BIT - 1)/__WORD_BIT;
    __stl_debug_do(_M_iter_list._Safe_init(&_M_start));
    _M_start = _Make_iterator(__q, 0, false);
    __stl_debug_do(_M_start._Set_overrun(true));
    _M_finish = _M_start + difference_type(__n);
    __stl_debug_do(_Init_bounds());
  }
  void _M_insert_aux(iterator __position, bool __x) {
    __stl_debug_do(_M_finish._Set_overrun(true));
    if (_M_finish._M_p != _M_end_of_storage._M_data) {
      copy_backward(__position, _M_finish, _M_finish + 1);
      *__position = __x;
      ++_M_finish;
    }
    else {
      size_type __len = size() ? 2 * size() : __WORD_BIT;
      unsigned int* __q = _M_bit_alloc(__len);
      iterator __i = copy(begin(), __position, _Make_iterator(__q, 0, true));
      *__i++ = __x;
      _M_finish = copy(__position, end(), __i);
      __stl_debug_do(_M_iter_list._Orphan(_M_finish));
      _M_deallocate();
      _M_end_of_storage._M_data = __q + (__len + __WORD_BIT - 1)/__WORD_BIT;
      _M_start = _Make_iterator(__q, 0, false);
      __stl_debug_do(_M_iter_list._Orphan(_M_start));
    }
    __stl_debug_do(_M_finish._Set_overrun(false));
  }

#ifdef __STL_MEMBER_TEMPLATES
  template <class _InputIterator>
  void _M_initialize_range(_InputIterator __first, _InputIterator __last,
			input_iterator_tag) {
    __stl_debug_check(__check_range(__first,__last));
    __stl_debug_do(_Safe_init(&_M_start));
    _M_start = iterator();
    _M_finish = iterator();
    __stl_debug_do(_Init_bounds());
    _M_end_of_storage._M_data = 0;
# if defined (__STL_DEBUG) && defined (__STL_USE_EXCEPTIONS)
    try {
# endif
      for ( ; __first != __last; ++__first) 
        push_back(*__first);
# if defined (__STL_DEBUG) && defined (__STL_USE_EXCEPTIONS)
    }
    catch (...) {
      __stl_debug_do(_M_start._Invalidate());
      __stl_debug_do(_M_finish._Invalidate());
      __stl_debug_do(_M_iter_list._Invalidate());        
    }
# endif
  }

  template <class _ForwardIterator>
  void _M_initialize_range(_ForwardIterator __first, _ForwardIterator __last,
                           forward_iterator_tag) {
    size_type __n = 0;
    distance(__first, __last, __n);
    _M_initialize(__n);
    copy(__first, __last, _M_start);
  }

  template <class _InputIterator>
  void _M_insert_range(iterator __pos,
                       _InputIterator __first, _InputIterator __last,
                       input_iterator_tag) {
    for ( ; __first != __last; ++__first) {
      __pos = insert(__pos, *__first);
      ++__pos;
    }
  }

  template <class _ForwardIterator>
  void _M_insert_range(iterator __position,
                       _ForwardIterator __first, _ForwardIterator __last,
                       forward_iterator_tag) {
    __stl_debug_check(__check_range(__first,__last));
    if (__first != __last) {
      size_type __n = 0;
      distance(__first, __last, __n);
      __stl_debug_do(_M_finish._Set_overrun(true));
      __stl_debug_do(__position._Set_overrun(true));
      if (capacity() - size() >= __n) {
        copy_backward(__position, end(), _M_finish + difference_type(__n));
        copy(__first, __last, __position);
        _M_finish += difference_type(__n);
      }
      else {
        size_type __len = size() + max(size(), __n);
        unsigned int* __q = _M_bit_alloc(__len);
        iterator __i = copy(begin(), __position, _Make_iterator(__q, 0, true));
        __i = copy(__first, __last, __i);
        _M_finish = copy(__position, end(), __i);
	__stl_debug_do(_M_iter_list._Orphan(_M_finish));
        _M_deallocate();
        _M_end_of_storage._M_data = __q + (__len + __WORD_BIT - 1)/__WORD_BIT;
        _M_start = _Make_iterator(__q, 0, false);
	__stl_debug_do(_M_iter_list._Orphan(_M_start));
      }
    }
    __stl_debug_do(_M_finish._Set_overrun(false));
  }      

#endif /* __STL_MEMBER_TEMPLATES */

public:
  iterator begin() { return _M_start; }
  const_iterator begin() const { return *(const const_iterator*)&_M_start; }
  iterator end() { return _M_finish; }
  const_iterator end() const { return *(const const_iterator*)&_M_finish; }

  reverse_iterator rbegin() { return reverse_iterator(end()); }
  const_reverse_iterator rbegin() const { 
    return const_reverse_iterator(end()); 
  }
  reverse_iterator rend() { return reverse_iterator(begin()); }
  const_reverse_iterator rend() const { 
    return const_reverse_iterator(begin()); 
  }

  size_type size() const { return size_type(end() - begin()); }
  size_type max_size() const { return size_type(-1); }
  size_type capacity() const {
    return size_type(_Make_const_iterator(_M_end_of_storage._M_data, 0, false) - begin());
  }
  bool empty() const { return begin() == end(); }
  reference operator[](size_type __n) 
  { return *(begin() + difference_type(__n)); }
  const_reference operator[](size_type __n) const 
  { return *(begin() + difference_type(__n)); }

#ifdef __STL_THROW_RANGE_ERRORS
  void _M_range_check(size_type __n) const {
    if (__n >= this->size())
      __stl_throw_range_error("vector<bool>");
  }

  reference at(size_type __n)
    { _M_range_check(__n); return (*this)[__n]; }
  const_reference at(size_type __n) const
    { _M_range_check(__n); return (*this)[__n]; }
#endif /* __STL_THROW_RANGE_ERRORS */


  explicit __BVECTOR(const allocator_type& __a = 
		     __STL_ALLOC_INSTANCE(allocator_type))
    : _Bvector_base<_Alloc >(__a) {}

  __BVECTOR(size_type __n, bool __value,
            const allocator_type& __a = 
	    __STL_ALLOC_INSTANCE(allocator_type))
    : _Bvector_base<_Alloc >(__a)
  {
    _M_initialize(__n);
    fill(_M_start._M_p, (__chunk_type*)_M_end_of_storage._M_data, __value ? ~0 : 0);
  }

  explicit __BVECTOR(size_type __n)
    : _Bvector_base<_Alloc >(allocator_type())
  {
    _M_initialize(__n);
    fill(_M_start._M_p, (__chunk_type*)_M_end_of_storage._M_data, 0);
  }

  __BVECTOR(const _Self& __x) : _Bvector_base<_Alloc >(__x.get_allocator()) {
    _M_initialize(__x.size());
    copy(__x.begin(), __x.end(), _M_start);
  }

#if defined (__STL_MEMBER_TEMPLATES) && !(defined (__GNUC__) && __GNUC_MINOR__ < 90) 
  // Check whether it's an integral type.  If so, it's not an iterator.
  template <class _InputIterator>
  __BVECTOR(_InputIterator __first, _InputIterator __last,
            const allocator_type& __a = __STL_ALLOC_INSTANCE(allocator_type))
    : _Base(__a)
  {
    typedef typename _Is_integer<_InputIterator>::_Integral _Integral;
    _M_initialize_dispatch(__first, __last, _Integral());
  }
    
  template <class _Integer>
  void _M_initialize_dispatch(_Integer __n, _Integer __x, __true_type) {
    _M_initialize(__n);
    fill(_M_start._M_p, _M_end_of_storage._M_data, __x ? ~0 : 0);
  }
    
  template <class _InputIterator>
  void _M_initialize_dispatch(_InputIterator __first, _InputIterator __last,
                              __false_type) {
    _M_initialize_range(__first, __last, __ITERATOR_CATEGORY(__first));
  }
#else /* __STL_MEMBER_TEMPLATES */
  __BVECTOR(const_iterator __first, const_iterator __last,
            const allocator_type& __a = __STL_ALLOC_INSTANCE(allocator_type))
    : _Bvector_base<_Alloc >(__a)
  {
    size_type __n = 0;
    distance(__first, __last, __n);
    _M_initialize(__n);
    copy(__first, __last, _M_start);
  }
  __BVECTOR(const bool* __first, const bool* __last,
            const allocator_type& __a = __STL_ALLOC_INSTANCE(allocator_type))
    : _Bvector_base<_Alloc >(__a)
  {
    size_type __n = 0;
    distance(__first, __last, __n);
    _M_initialize(__n);
    copy(__first, __last, _M_start);
  }
#endif /* __STL_MEMBER_TEMPLATES */

  ~__BVECTOR() { }

  __BVECTOR_QUALIFIED& operator=(const __BVECTOR_QUALIFIED& __x) {
    if (&__x == this) return *this;
    __stl_debug_do(_Invalidate_all());
    if (__x.size() > capacity()) {
      _M_deallocate();
      _M_initialize(__x.size());
    }
    copy(__x.begin(), __x.end(), begin());
    _M_finish = begin() + difference_type(__x.size());
    __stl_debug_do(_M_iter_list._Orphan(_M_finish));
    return *this;
  }

  // assign(), a generalized assignment member function.  Two
  // versions: one that takes a count, and one that takes a range.
  // The range version is a member template, so we dispatch on whether
  // or not the type is an integer.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看日韩一区| 亚洲一级二级三级| 亚洲精品自拍动漫在线| 午夜精品久久久久久久久| 国产精品一区二区在线播放| 欧美日韩国产精选| 国产精品视频一二三区| 九色|91porny| 3d成人h动漫网站入口| 亚洲乱码中文字幕综合| 国产999精品久久久久久| 日韩精品在线一区| 亚洲福利一区二区| 91日韩精品一区| 中文字幕成人在线观看| 国产一区二区精品在线观看| 欧美一区二区三区爱爱| 婷婷久久综合九色综合绿巨人| 99国产精品视频免费观看| 国产日韩欧美在线一区| 国产一区二区三区久久久| 欧美一级理论片| 午夜久久久久久久久久一区二区| 欧美中文字幕久久| 亚洲免费成人av| 91蝌蚪porny成人天涯| 国产精品久久一卡二卡| 成人免费视频视频| 中文字幕制服丝袜一区二区三区| 成人午夜看片网址| 中文字幕在线观看一区二区| 欧美日韩中文一区| 亚洲综合激情小说| 欧美亚洲国产一区在线观看网站 | 成人激情免费网站| 国产欧美一区二区三区网站| 国产99一区视频免费| 国产精品久久精品日日| 91一区二区三区在线播放| 亚洲卡通欧美制服中文| 色域天天综合网| 亚洲小说欧美激情另类| 欧美三级电影在线观看| 日韩精品一区第一页| 欧美一级高清大全免费观看| 狠狠色伊人亚洲综合成人| 国产无遮挡一区二区三区毛片日本| 国产不卡一区视频| 亚洲蜜桃精久久久久久久| 欧美色精品在线视频| 美腿丝袜一区二区三区| 国产亚洲福利社区一区| 99热这里都是精品| 婷婷久久综合九色综合伊人色| 欧美一区二区免费视频| 国产91精品在线观看| 一区二区成人在线| 欧美精品电影在线播放| 国产高清不卡一区| 亚洲欧美电影一区二区| 91精品国产一区二区三区蜜臀| 国产精品一区二区黑丝| 亚洲免费观看视频| 337p粉嫩大胆噜噜噜噜噜91av| 成人国产在线观看| 日韩高清不卡一区二区三区| 久久久电影一区二区三区| 色婷婷av一区二区三区大白胸 | 欧美日韩国产不卡| 国内久久婷婷综合| 一区二区高清视频在线观看| 精品女同一区二区| 色欧美日韩亚洲| 国产在线观看免费一区| 亚洲一区二区三区四区在线观看| 久久这里只有精品首页| 色88888久久久久久影院野外| 免费高清成人在线| 亚洲欧洲日本在线| 欧美成人aa大片| 欧美午夜精品免费| 福利电影一区二区| 天堂久久久久va久久久久| 欧美国产日韩亚洲一区| 日韩欧美亚洲国产另类 | 日韩精品一区二区三区在线| av福利精品导航| 美腿丝袜亚洲综合| 1000部国产精品成人观看| 欧美精品一区二区不卡| 欧美久久久影院| 日本高清视频一区二区| 国产成人h网站| 韩日精品视频一区| 免费的成人av| 日本午夜一本久久久综合| 一区二区三区日韩精品| 国产精品看片你懂得| 国产亚洲va综合人人澡精品| 日韩亚洲欧美中文三级| 51午夜精品国产| 欧美日韩国产免费| 欧洲人成人精品| 在线亚洲免费视频| 91小视频免费看| 99精品欧美一区二区蜜桃免费| 国产激情91久久精品导航| 久久国内精品视频| 久久国产精品无码网站| 日本va欧美va精品发布| 水蜜桃久久夜色精品一区的特点| 亚洲综合久久av| 亚洲成av人影院| 亚洲成人综合在线| 天天综合网天天综合色| 亚洲国产精品久久久久婷婷884| 一区二区三区欧美日韩| 亚洲卡通欧美制服中文| 亚洲一区二区免费视频| 亚洲成人黄色影院| 免费亚洲电影在线| 国内久久精品视频| 国产高清在线观看免费不卡| 成人午夜伦理影院| 91一区二区三区在线播放| 欧美亚洲综合在线| 欧美精品一级二级| 欧美精品一区二区在线观看| 久久久久国产成人精品亚洲午夜| 国产日韩欧美不卡在线| 亚洲欧美影音先锋| 午夜欧美电影在线观看| 蓝色福利精品导航| 国产精品一二一区| 91丨九色丨国产丨porny| 在线这里只有精品| 日韩欧美亚洲国产另类| 久久精品亚洲精品国产欧美kt∨| 中文字幕在线不卡视频| 五月天婷婷综合| 国产成人免费在线视频| 日本高清不卡aⅴ免费网站| 欧美一区二区女人| 国产精品久久久久aaaa樱花| 无码av中文一区二区三区桃花岛| 久久99精品久久久久久国产越南 | 国产在线麻豆精品观看| www.日韩在线| 欧美一区二区三区四区五区| 国产网站一区二区三区| 亚洲午夜在线电影| 国产在线精品视频| 欧美这里有精品| 精品国产乱码91久久久久久网站| 国产精品卡一卡二| 青青草成人在线观看| 成人综合在线视频| 91精品国产入口| 中文字幕一区二区三区不卡| 另类综合日韩欧美亚洲| 99国产精品久久久久| 精品va天堂亚洲国产| 亚洲一区二区三区中文字幕 | 日韩精品五月天| 成人一区二区视频| 欧美一区二区日韩| 26uuu国产日韩综合| 国产精品嫩草影院com| 日韩国产一二三区| 99久久婷婷国产综合精品电影| 欧美一区二区视频观看视频| 国产精品成人免费| 国产精品乡下勾搭老头1| 欧美一区日本一区韩国一区| 亚洲欧美日韩国产中文在线| 国产美女一区二区| 日韩一二三区不卡| 亚洲高清免费视频| 91视视频在线观看入口直接观看www | 色综合久久综合| 久久精品人人做| 紧缚捆绑精品一区二区| 欧美日韩久久久一区| 亚洲色图色小说| 99热在这里有精品免费| 久久久久久久久久久久久夜| 奇米在线7777在线精品| 欧美午夜一区二区| 一区二区三区电影在线播| heyzo一本久久综合| 中文字幕欧美日本乱码一线二线| 精品在线播放免费| 2014亚洲片线观看视频免费| 美女高潮久久久| 欧美成人一区二区三区片免费 | 亚洲精品菠萝久久久久久久| 成人av免费在线| 中文字幕在线免费不卡| 91视频免费播放| 一区二区三区在线视频观看|