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

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

?? stl_set.h

?? 粗慥集成算法集合 ,并有詳細的文檔資料和測試數據處
?? H
字號:
/*
 *
 * Copyright (c) 1994
 * Hewlett-Packard Company
 *
 * Copyright (c) 1996,1997
 * Silicon Graphics Computer Systems, Inc.
 *
 * Copyright (c) 1997
 * Moscow Center for SPARC Technology
 *
 * Copyright (c) 1999 
 * Boris Fomitchev
 *
 * This material is provided "as is", with absolutely no warranty expressed
 * or implied. Any use is at your own risk.
 *
 * Permission to use or copy this software for any purpose is hereby granted 
 * without fee, provided the above notices are retained on all copies.
 * Permission to modify the code and to distribute modified code is granted,
 * provided the above notices are retained, and a notice that the code was
 * modified is included with the above copyright notice.
 *
 */

/* NOTE: This is an internal header file, included by other STL headers.
 *   You should not attempt to use it directly.
 */

#ifndef __SGI_STL_INTERNAL_SET_H
#define __SGI_STL_INTERNAL_SET_H

#if defined(__sgi) && !defined(__GNUC__) && (_MIPS_SIM != _MIPS_SIM_ABI32)
#pragma set woff 1174
#pragma set woff 1375
#endif
#define set __WORKAROUND_RENAME(set)

__STL_BEGIN_NAMESPACE

template <class _Key, __DFL_TMPL_PARAM(_Compare,less<_Key>), 
                     __STL_DEFAULT_ALLOCATOR_SELECT(_Key) >
class set {
public:
// typedefs:
  typedef _Key     key_type;
  typedef _Key     value_type;
  typedef _Compare key_compare;
  typedef _Compare value_compare;
private:
  typedef _Rb_tree<key_type, value_type, 
                  _Identity<value_type>, key_compare, _Alloc> _Rep_type;
public:
  typedef typename _Rep_type::const_pointer pointer;
  typedef typename _Rep_type::const_pointer const_pointer;
  typedef typename _Rep_type::const_reference reference;
  typedef typename _Rep_type::const_reference const_reference;
  typedef typename _Rep_type::const_iterator const_iterator;
  typedef const_iterator iterator;
  typedef typename _Rep_type::const_reverse_iterator reverse_iterator;
  typedef typename _Rep_type::const_reverse_iterator const_reverse_iterator;
  typedef typename _Rep_type::size_type size_type;
  typedef typename _Rep_type::difference_type difference_type;
  typedef typename _Rep_type::allocator_type allocator_type;

private:
  _Rep_type _M_t;  // red-black tree representing set
public:

  // allocation/deallocation

  set() : _M_t(_Compare(), allocator_type()) {}
  explicit set(const _Compare& __comp,
	       const allocator_type& __a = __STL_ALLOC_INSTANCE(allocator_type))
    : _M_t(__comp, __a) {}

#ifdef __STL_MEMBER_TEMPLATES
  template <class _InputIterator>
  set(_InputIterator __first, _InputIterator __last)
    : _M_t(_Compare(), allocator_type())
    { _M_t.insert_unique(__first, __last); }

  template <class _InputIterator>
  set(_InputIterator __first, _InputIterator __last, const _Compare& __comp,
      const allocator_type& __a = __STL_ALLOC_INSTANCE(allocator_type))
    : _M_t(__comp, __a) { _M_t.insert_unique(__first, __last); }
#else
  set(const value_type* __first, const value_type* __last) 
    : _M_t(_Compare(), allocator_type()) 
    { _M_t.insert_unique(__first, __last); }

  set(const value_type* __first, 
      const value_type* __last, const _Compare& __comp,
      const allocator_type& __a = __STL_ALLOC_INSTANCE(allocator_type))
    : _M_t(__comp, __a) { _M_t.insert_unique(__first, __last); }

  set(const_iterator __first, const_iterator __last)
    : _M_t(_Compare(), allocator_type()) 
    { _M_t.insert_unique(__first, __last); }

  set(const_iterator __first, const_iterator __last, const _Compare& __comp,
      const allocator_type& __a = __STL_ALLOC_INSTANCE(allocator_type))
    : _M_t(__comp, __a) { _M_t.insert_unique(__first, __last); }
#endif /* __STL_MEMBER_TEMPLATES */

  set(const set<_Key,_Compare,_Alloc>& __x) : _M_t(__x._M_t) {}
  set<_Key,_Compare,_Alloc>& operator=(const set<_Key, _Compare, _Alloc>& __x)
  { 
    _M_t = __x._M_t; 
    return *this;
  }

  // accessors:

  key_compare key_comp() const { return _M_t.key_comp(); }
  value_compare value_comp() const { return _M_t.key_comp(); }
  allocator_type get_allocator() const { return _M_t.get_allocator(); }

  iterator begin() const { return _M_t.begin(); }
  iterator end() const { return _M_t.end(); }
  reverse_iterator rbegin() const { return _M_t.rbegin(); } 
  reverse_iterator rend() const { return _M_t.rend(); }
  bool empty() const { return _M_t.empty(); }
  size_type size() const { return _M_t.size(); }
  size_type max_size() const { return _M_t.max_size(); }
  void swap(set<_Key,_Compare,_Alloc>& __x) { _M_t.swap(__x._M_t); }

  // insert/erase
  pair<iterator,bool> insert(const value_type& __x) { 
    typedef typename _Rep_type::iterator _Rep_iterator;
    pair<_Rep_iterator, bool> __p = _M_t.insert_unique(__x); 
    return pair<iterator, bool>((const iterator&)__p.first, __p.second);
  }
  iterator insert(iterator __position, const value_type& __x) {
    typedef typename _Rep_type::iterator _Rep_iterator;
    return _M_t.insert_unique((_Rep_iterator&)__position, __x);
  }
#ifdef __STL_MEMBER_TEMPLATES
  template <class _InputIterator>
  void insert(_InputIterator __first, _InputIterator __last) {
    _M_t.insert_unique(__first, __last);
  }
#else
  void insert(const_iterator __first, const_iterator __last) {
    _M_t.insert_unique(__first, __last);
  }
  void insert(const value_type* __first, const value_type* __last) {
    _M_t.insert_unique(__first, __last);
  }
#endif /* __STL_MEMBER_TEMPLATES */
  void erase(iterator __position) { 
    typedef typename _Rep_type::iterator _Rep_iterator;
    _M_t.erase((_Rep_iterator&)__position); 
  }
  size_type erase(const key_type& __x) { 
    return _M_t.erase(__x); 
  }
  void erase(iterator __first, iterator __last) { 
    typedef typename _Rep_type::iterator _Rep_iterator;
    _M_t.erase((_Rep_iterator&)__first, (_Rep_iterator&)__last); 
  }
  void clear() { _M_t.clear(); }

  // set operations:

  iterator find(const key_type& __x) const { return _M_t.find(__x); }
  size_type count(const key_type& __x) const { return _M_t.count(__x); }
  iterator lower_bound(const key_type& __x) const {
    return _M_t.lower_bound(__x);
  }
  iterator upper_bound(const key_type& __x) const {
    return _M_t.upper_bound(__x); 
  }
  pair<iterator,iterator> equal_range(const key_type& __x) const {
    return _M_t.equal_range(__x);
  }
};

template <class _Key, class _Compare, class _Alloc>
inline bool operator==(const set<_Key,_Compare,_Alloc>& __x, 
                       const set<_Key,_Compare,_Alloc>& __y) {
  return __x.size() == __y.size() &&
         equal(__x.begin(), __x.end(), __y.begin());
}

template <class _Key, class _Compare, class _Alloc>
inline bool operator<(const set<_Key,_Compare,_Alloc>& __x, 
                      const set<_Key,_Compare,_Alloc>& __y) {
  return lexicographical_compare(__x.begin(), __x.end(), 
                                 __y.begin(), __y.end());
}

#ifdef __STL_USE_SEPARATE_RELOPS_NAMESPACE

template <class _Key, class _Compare, class _Alloc>
inline bool operator!=(const set<_Key,_Compare,_Alloc>& __x, 
                       const set<_Key,_Compare,_Alloc>& __y) {
  return !(__x == __y);
}

template <class _Key, class _Compare, class _Alloc>
inline bool operator>(const set<_Key,_Compare,_Alloc>& __x, 
                      const set<_Key,_Compare,_Alloc>& __y) {
  return __y < __x;
}

template <class _Key, class _Compare, class _Alloc>
inline bool operator<=(const set<_Key,_Compare,_Alloc>& __x, 
                       const set<_Key,_Compare,_Alloc>& __y) {
  return !(__y < __x);
}

template <class _Key, class _Compare, class _Alloc>
inline bool operator>=(const set<_Key,_Compare,_Alloc>& __x, 
                       const set<_Key,_Compare,_Alloc>& __y) {
  return !(__x < __y);
}
#endif /* __STL_USE_SEPARATE_RELOPS_NAMESPACE */

#ifdef __STL_FUNCTION_TMPL_PARTIAL_ORDER

template <class _Key, class _Compare, class _Alloc>
inline void swap(set<_Key,_Compare,_Alloc>& __x, 
                 set<_Key,_Compare,_Alloc>& __y) {
  __x.swap(__y);
}

#endif /* __STL_FUNCTION_TMPL_PARTIAL_ORDER */

// do a cleanup
# undef set
// provide a way to access full funclionality 
# define __set__  __FULL_NAME(set)

# ifdef __STL_USE_WRAPPER_FOR_ALLOC_PARAM

#  if defined (__STL_MINIMUM_DEFAULT_TEMPLATE_PARAMS)
#   define __SET_TEMPLATE_HEADER  template <class _Key>
#   define __SET_ARGUMENTS        _Key
#   define _Compare less<_Key>
#  else
#   define __SET_TEMPLATE_HEADER  template <class _Key, class _Compare >
#   define __SET_ARGUMENTS        _Key, _Compare
#  endif

#   define __SET_SUPER  __set< _Key, _Compare, __STL_DEFAULT_ALLOCATOR(_Key) >

// provide a "default" set adaptor
__SET_TEMPLATE_HEADER
class set : public __SET_SUPER
{
  typedef set< __SET_ARGUMENTS > _Self;
public:
    typedef __SET_SUPER _Super;
    __IMPORT_WITH_REVERSE_ITERATORS(_Super)
    // copy & assignment from super
    __IMPORT_SUPER_COPY_ASSIGNMENT(set,_Self,__SET_SUPER)
    // specific constructors
    explicit set() : __SET_SUPER(_Compare()) {}
    explicit set(const _Compare& __comp) : __SET_SUPER(__comp) {}
    set(const value_type* __first, const value_type* __last) : 
        __SET_SUPER(__first, __last, _Compare()) { }
    set(const value_type* __first, const value_type* __last, 
        const _Compare& __comp) : __SET_SUPER(__first, __last, __comp) { }
    set(const_iterator __first, const_iterator __last) : 
        __SET_SUPER(__first, __last, _Compare()) { }
    set(const_iterator __first, const_iterator __last, 
        const _Compare& __comp) : __SET_SUPER(__first, __last, __comp) { }
};

#  if defined (__STL_BASE_MATCH_BUG)
__SET_TEMPLATE_HEADER 
inline bool operator==(const set< __SET_ARGUMENTS >& __x, 
                       const set< __SET_ARGUMENTS >& __y) {
  typedef __SET_SUPER _Super;
  return operator==((const _Super&)__x,(const _Super&)__y);
}

__SET_TEMPLATE_HEADER 
inline bool operator<(const set< __SET_ARGUMENTS >& __x, 
                      const set< __SET_ARGUMENTS >& __y) {
  typedef __SET_SUPER _Super;
  return operator < ((const _Super&)__x , (const _Super&)__y);
}
#  endif

# undef __SET_TEMPLATE_HEADER
# undef __SET_ARGUMENTS
# undef __SET_SUPER 
# undef _Compare

# endif /*  WRAPPER */

#if defined(__sgi) && !defined(__GNUC__) && (_MIPS_SIM != _MIPS_SIM_ABI32)
#pragma reset woff 1174
#pragma reset woff 1375
#endif

__STL_END_NAMESPACE

#endif /* __SGI_STL_INTERNAL_SET_H */

// Local Variables:
// mode:C++
// End:

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区在线不卡| 精品视频一区三区九区| 亚洲精品日日夜夜| 欧美一区二区观看视频| 成人永久免费视频| 青青草国产精品97视觉盛宴| 国产精品久久99| 欧美变态口味重另类| 91视频精品在这里| 国产精品自拍av| 日日夜夜精品免费视频| 综合自拍亚洲综合图不卡区| 久久久亚洲午夜电影| 制服.丝袜.亚洲.另类.中文| 97精品国产露脸对白| 国产成人免费在线| 蜜臀av一区二区在线免费观看 | 亚洲国产aⅴ天堂久久| 中文字幕av一区二区三区高| 日韩视频一区二区在线观看| 欧美亚洲综合网| 99综合电影在线视频| 国内欧美视频一区二区| 蜜桃传媒麻豆第一区在线观看| 亚洲制服丝袜一区| 亚洲久草在线视频| 亚洲欧美日韩中文播放| 亚洲国产精品v| 国产欧美一区视频| 26uuu另类欧美亚洲曰本| 日韩一级黄色片| 91精品婷婷国产综合久久性色 | 972aa.com艺术欧美| 国产福利一区在线观看| 国产一区二区免费在线| 国内精品国产成人国产三级粉色| 免费欧美在线视频| 免费成人av资源网| 老司机精品视频一区二区三区| 日本强好片久久久久久aaa| 日韩精品欧美精品| 婷婷丁香久久五月婷婷| 天天色综合天天| 日本女优在线视频一区二区| 日韩国产一二三区| 韩国女主播一区二区三区| 韩国精品主播一区二区在线观看 | 国产精品无码永久免费888| 欧美国产在线观看| 日韩一区在线播放| 一区二区三区在线不卡| 亚洲综合成人网| 日韩精品国产精品| 精品系列免费在线观看| 国产毛片精品国产一区二区三区| 粉嫩一区二区三区在线看| 99久久综合精品| 色一情一乱一乱一91av| 欧美另类一区二区三区| 欧美大片拔萝卜| 久久久久国产精品厨房| 国产精品福利一区二区| 亚洲一区二区在线播放相泽| 视频一区二区不卡| 国内精品久久久久影院薰衣草| 成人性视频免费网站| 91精品福利视频| 日韩免费一区二区| 国产日产欧美精品一区二区三区| 亚洲日本va午夜在线电影| 午夜欧美大尺度福利影院在线看| 麻豆精品一区二区av白丝在线| 国产乱一区二区| 色域天天综合网| 欧美一区二区三区精品| 欧美国产综合一区二区| 亚洲va韩国va欧美va精品| 经典三级在线一区| 99精品视频在线播放观看| 制服丝袜成人动漫| 国产精品毛片久久久久久| 亚洲va天堂va国产va久| 国产大陆亚洲精品国产| 欧美丝袜丝nylons| 久久久综合视频| 亚洲国产精品视频| 国产久卡久卡久卡久卡视频精品| 欧美亚洲愉拍一区二区| 国产欧美一区二区精品性色| 亚洲夂夂婷婷色拍ww47| 国产成人综合在线| 69精品人人人人| 中文字幕中文字幕一区| 免费看日韩a级影片| 一本一道久久a久久精品| 久久综合一区二区| 五月天视频一区| 99久久er热在这里只有精品15| 欧美一卡在线观看| 亚洲精品一二三四区| 国产激情一区二区三区桃花岛亚洲| 欧美无砖专区一中文字| 国产精品久久久久久久裸模| 久久99久久精品欧美| 在线看日韩精品电影| 中文av一区特黄| 激情欧美一区二区| 717成人午夜免费福利电影| 1000精品久久久久久久久| 国产在线精品一区二区不卡了 | 极品美女销魂一区二区三区| 在线中文字幕不卡| 最新日韩av在线| 国产精品18久久久久久vr| 欧美一级黄色录像| 视频一区二区中文字幕| 欧洲国内综合视频| 亚洲激情图片qvod| 成人禁用看黄a在线| 久久久亚洲欧洲日产国码αv| 免费观看在线色综合| 欧美精品视频www在线观看| 一区二区三区免费| 99视频在线观看一区三区| 欧美国产精品v| 国产成人av电影在线| 精品国产麻豆免费人成网站| 日韩不卡手机在线v区| 欧美色手机在线观看| 亚洲一区二区欧美| 欧美日韩一级二级| 亚洲一区二区三区四区五区中文| 91美女片黄在线观看| 一区二区三区精品视频在线| 91麻豆福利精品推荐| 亚洲另类在线制服丝袜| 91视频一区二区三区| 一级中文字幕一区二区| 欧美午夜精品一区| 日一区二区三区| 欧美一区2区视频在线观看| 麻豆91在线播放免费| 日韩一区二区在线看| 久久er精品视频| 久久影院电视剧免费观看| 国产一区二区三区最好精华液| 日韩免费视频线观看| 国产精品资源站在线| 中文一区在线播放| av在线不卡电影| 亚洲欧美激情在线| 欧美日韩另类一区| 日本成人超碰在线观看| 精品粉嫩超白一线天av| 国内精品在线播放| 亚洲欧洲色图综合| 欧美日韩一区二区欧美激情| 日本vs亚洲vs韩国一区三区| 久久女同精品一区二区| www.日本不卡| 午夜影视日本亚洲欧洲精品| 欧美一级片在线看| 国产一区二区久久| 日韩一区在线播放| 欧美欧美欧美欧美| 国产一区二区三区免费看| 国产精品九色蝌蚪自拍| 欧美日韩一级片在线观看| 免费观看一级特黄欧美大片| 中文一区二区完整视频在线观看| 91视频免费观看| 免费av成人在线| 国产精品久久免费看| 欧美日韩精品一区二区三区蜜桃| 另类中文字幕网| 亚洲同性同志一二三专区| 欧美一区二区精品久久911| 国产成人在线视频网址| 亚洲一卡二卡三卡四卡 | 国产精品久久久久影院老司| 欧美日韩一二三| 国产精品性做久久久久久| 亚洲一二三四久久| 日韩一区二区精品在线观看| 成人午夜碰碰视频| 日韩精品亚洲专区| 亚洲国产精品高清| 5858s免费视频成人| www.日韩在线| 激情丁香综合五月| 亚洲伊人色欲综合网| 国产亚洲欧美在线| 7777精品伊人久久久大香线蕉完整版| 国产精品911| 日本aⅴ精品一区二区三区 | 亚洲欧美日韩在线| 久久中文娱乐网| 欧美久久高跟鞋激| 91在线观看污| 国产91精品免费|