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

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

?? stl_hashtable.c

?? 粗慥集成算法集合 ,并有詳細的文檔資料和測試數據處
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
 *
 *
 * 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.
 *
 */
#ifndef __STL_HASHTABLE_C
#define __STL_HASHTABLE_C

__STL_BEGIN_NAMESPACE

#if ( __STL_STATIC_TEMPLATE_DATA > 0 )
   template <class _Tp>
   _Tp _Stl_prime<_Tp>::_M_list[__stl_num_primes]
#  else
#  if ( __STL_WEAK_ATTRIBUTE > 0 )
      const unsigned long __stl_prime_list[__stl_num_primes] __attribute__((weak))
#  else
      // give up
   static const unsigned long __stl_prime_list[__stl_num_primes]
#  endif /* __STL_WEAK_ATTRIBUTE */
#endif /* __STL_STATIC_TEMPLATE_DATA */
 = {
  53ul,         97ul,         193ul,       389ul,       769ul,
  1543ul,       3079ul,       6151ul,      12289ul,     24593ul,
  49157ul,      98317ul,      196613ul,    393241ul,    786433ul,
  1572869ul,    3145739ul,    6291469ul,   12582917ul,  25165843ul,
  50331653ul,   100663319ul,  201326611ul, 402653189ul, 805306457ul, 
  1610612741ul, 3221225473ul, 4294967291ul
};

// fbp: these defines are for outline methods definitions.
// needed to definitions to be portable. Should not be used in method bodies.

# if defined ( __STL_NESTED_TYPE_PARAM_BUG )
#  define __difference_type__ ptrdiff_t
#  define __size_type__       size_t
#  define __value_type__      _Val
#  define __key_type__        _Key
#  define __node__            _Hashtable_node<_Val>
#  define __reference__       _Val&
#  define __iterator__        _Ht_iterator<_Val, _Nonconst_traits<_Val>, _Key, _HF, _ExK, _EqK, _All>
#  define __const_iterator__  _Ht_iterator<_Val, _Const_traits<_Val>, _Key, _HF, _ExK, _EqK, _All>
# else
#  define __difference_type__  typename hashtable<_Val, _Key, _HF, _ExK, _EqK, _All>::difference_type
#  define __size_type__        __STL_TYPENAME_ON_RETURN_TYPE hashtable<_Val, _Key, _HF, _ExK, _EqK, _All>::size_type
#  define __value_type__       __STL_TYPENAME_ON_RETURN_TYPE hashtable<_Val, _Key, _HF, _ExK, _EqK, _All>::value_type
#  define __key_type__         __STL_TYPENAME_ON_RETURN_TYPE hashtable<_Val, _Key, _HF, _ExK, _EqK, _All>::key_type
#  define __node__             __STL_TYPENAME_ON_RETURN_TYPE hashtable<_Val, _Key, _HF, _ExK, _EqK, _All>::_Node
#  define __reference__        __STL_TYPENAME_ON_RETURN_TYPE  hashtable<_Val, _Key, _HF, _ExK, _EqK, _All>::reference
#  define __iterator__         __STL_TYPENAME_ON_RETURN_TYPE hashtable<_Val, _Key, _HF, _ExK, _EqK, _All>::iterator
#  define __const_iterator__   __STL_TYPENAME_ON_RETURN_TYPE hashtable<_Val, _Key, _HF, _ExK, _EqK, _All>::const_iterator
# endif

template <class _Val, class _Key, class _HF, class _ExK, class _EqK, 
          class _All>
_Hashtable_node<_Val>*
_Hashtable_iterator<_Val,_Key,_HF,_ExK,_EqK,_All>::_M_skip_to_next() {
  size_t __bucket = _M_ht->_M_bkt_num(_M_cur->_M_val);
  size_t __h_sz;
  __h_sz = this->_M_ht->bucket_count();

  _Node* __i=0;
  while (__i==0 && ++__bucket < __h_sz)
    __i = _M_ht->_M_buckets[__bucket];
  return __i;
}

template <class _Val, class _Key, class _HF, class _ExK, class _EqK, class _All>
bool 
hashtable<_Val,_Key,_HF,_ExK,_EqK,_All>::_M_equal(
						  const hashtable<_Val,_Key,_HF,_ExK,_EqK,_All>& __ht1,
						  const hashtable<_Val,_Key,_HF,_ExK,_EqK,_All>& __ht2)
{
  //  typedef _Hashtable_node<_Val> _Node;
  if (__ht1.bucket_count() != __ht2.bucket_count())
    return false;
  for (size_t __n = 0; __n < __ht1.bucket_count(); ++__n) {
    const _Node* __cur1 = __ht1._M_get_bucket(__n);
    const _Node* __cur2 = __ht2._M_get_bucket(__n);
    for ( ; __cur1 && __cur2 && __cur1->_M_val == __cur2->_M_val;
          __cur1 = __cur1->_M_next, __cur2 = __cur2->_M_next)
      {}
    if (__cur1 || __cur2)
      return false;
  }
  return true;
}  

template <class _Val, class _Key, class _HF, class _ExK, class _EqK, class _All>
pair<__iterator__, bool> 
hashtable<_Val,_Key,_HF,_ExK,_EqK,_All>
  ::insert_unique_noresize(const __value_type__& __obj)
{
  const size_type __n = _M_bkt_num(__obj);
  _Node* __first = _M_buckets[__n];

  for (_Node* __cur = __first; __cur; __cur = __cur->_M_next) 
    if (_M_equals(_M_get_key(__cur->_M_val), _M_get_key(__obj)))
      return pair<iterator, bool>(iterator(__cur, this), false);

  _Node* __tmp = _M_new_node(__obj);
  __tmp->_M_next = __first;
  _M_buckets[__n] = __tmp;
  ++_M_num_elements._M_data;
  return pair<iterator, bool>(iterator(__tmp, this), true);
}

template <class _Val, class _Key, class _HF, class _ExK, class _EqK, class _All>
__iterator__ 
hashtable<_Val,_Key,_HF,_ExK,_EqK,_All>
  ::insert_equal_noresize(const __value_type__& __obj)
{
  const size_type __n = _M_bkt_num(__obj);
  _Node* __first = _M_buckets[__n];

  for (_Node* __cur = __first; __cur; __cur = __cur->_M_next) 
    if (_M_equals(_M_get_key(__cur->_M_val), _M_get_key(__obj))) {
      _Node* __tmp = _M_new_node(__obj);
      __tmp->_M_next = __cur->_M_next;
      __cur->_M_next = __tmp;
      ++_M_num_elements._M_data;
      return iterator(__tmp, this);
    }

  _Node* __tmp = _M_new_node(__obj);
  __tmp->_M_next = __first;
  _M_buckets[__n] = __tmp;
  ++_M_num_elements._M_data;
  return iterator(__tmp, this);
}

template <class _Val, class _Key, class _HF, class _ExK, class _EqK, class _All>
__reference__ 
hashtable<_Val,_Key,_HF,_ExK,_EqK,_All>::find_or_insert(const __value_type__& __obj)
{
  resize(_M_num_elements._M_data + 1);

  size_type __n = _M_bkt_num(__obj);
  _Node* __first = _M_buckets[__n];

  for (_Node* __cur = __first; __cur; __cur = __cur->_M_next)
    if (_M_equals(_M_get_key(__cur->_M_val), _M_get_key(__obj)))
      return __cur->_M_val;

  _Node* __tmp = _M_new_node(__obj);
  __tmp->_M_next = __first;
  _M_buckets[__n] = __tmp;
  ++_M_num_elements._M_data;
  return __tmp->_M_val;
}

template <class _Val, class _Key, class _HF, class _ExK, class _EqK, class _All>
pair<__iterator__,
     __iterator__> 
hashtable<_Val,_Key,_HF,_ExK,_EqK,_All>::equal_range(const __key_type__& __key)
{
  typedef pair<iterator, iterator> _Pii;
  const size_type __n = _M_bkt_num_key(__key);

  for (_Node* __first = _M_buckets[__n]; __first; __first = __first->_M_next)
    if (_M_equals(_M_get_key(__first->_M_val), __key)) {
      for (_Node* __cur = __first->_M_next; __cur; __cur = __cur->_M_next)
        if (!_M_equals(_M_get_key(__cur->_M_val), __key))
          return _Pii(iterator(__first, this), iterator(__cur, this));
      for (size_type __m = __n + 1; __m < _M_buckets.size(); ++__m)
        if (_M_buckets[__m])
          return _Pii(iterator(__first, this),
                     iterator(_M_buckets[__m], this));
      return _Pii(iterator(__first, this), end());
    }
  return _Pii(end(), end());
}

template <class _Val, class _Key, class _HF, class _ExK, class _EqK, class _All>
pair<__const_iterator__, 
     __const_iterator__> 
hashtable<_Val,_Key,_HF,_ExK,_EqK,_All>
  ::equal_range(const __key_type__& __key) const
{
  typedef pair<const_iterator, const_iterator> _Pii;
  const size_type __n = _M_bkt_num_key(__key);

  for (const _Node* __first = _M_buckets[__n] ;
       __first; 
       __first = __first->_M_next) {
    if (_M_equals(_M_get_key(__first->_M_val), __key)) {
      for (const _Node* __cur = __first->_M_next;
           __cur;
           __cur = __cur->_M_next)
        if (!_M_equals(_M_get_key(__cur->_M_val), __key))
          return _Pii(const_iterator(__first, this),
                      const_iterator(__cur, this));
      for (size_type __m = __n + 1; __m < _M_buckets.size(); ++__m)
        if (_M_buckets[__m])
          return _Pii(const_iterator(__first, this),
                      const_iterator(_M_buckets[__m], this));
      return _Pii(const_iterator(__first, this), end());
    }
  }
  return _Pii(end(), end());
}

template <class _Val, class _Key, class _HF, class _ExK, class _EqK, class _All>
__size_type__ 
hashtable<_Val,_Key,_HF,_ExK,_EqK,_All>::erase(const __key_type__& __key)
{
  const size_type __n = _M_bkt_num_key(__key);
  _Node* __first = _M_buckets[__n];
  size_type __erased = 0;

  if (__first) {
    _Node* __cur = __first;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜精品免费在线| 日本午夜一区二区| 精品播放一区二区| 色婷婷久久99综合精品jk白丝| 亚洲成av人片在线| 最新热久久免费视频| 精品三级av在线| 欧美午夜精品理论片a级按摩| 国产精品一区久久久久| 日日骚欧美日韩| 亚洲免费观看高清完整版在线观看 | 国产美女视频一区| 亚洲自拍偷拍av| 亚洲欧美偷拍另类a∨色屁股| 久久综合久久久久88| 欧美精品777| 在线国产电影不卡| 91小视频免费观看| 高清在线不卡av| 黄页视频在线91| 免费视频一区二区| 婷婷亚洲久悠悠色悠在线播放| 综合色天天鬼久久鬼色| 国产免费久久精品| 久久久一区二区三区捆绑**| 欧美一区二区三区性视频| 欧美色区777第一页| 在线视频综合导航| 91啪亚洲精品| 91捆绑美女网站| 99久久综合精品| 丁香婷婷综合网| 国产91在线|亚洲| 国产成人在线影院| 国产一区二区成人久久免费影院 | 欧美日韩久久一区二区| 在线免费观看一区| 欧亚洲嫩模精品一区三区| 色综合久久中文字幕| 99re66热这里只有精品3直播| 成人精品高清在线| thepron国产精品| 91在线小视频| 在线免费观看不卡av| 在线一区二区三区做爰视频网站| 99国产精品视频免费观看| 99re免费视频精品全部| 91视频在线观看免费| 91猫先生在线| 欧美在线观看一区二区| 欧美日韩成人高清| 日韩天堂在线观看| 精品国产一区二区三区忘忧草| 337p粉嫩大胆噜噜噜噜噜91av | 中文字幕一区二区三区av| 国产精品久久99| 亚洲综合图片区| 免费在线一区观看| 国产一区二区在线观看免费| 国产69精品久久99不卡| www.日韩精品| 欧美人妇做爰xxxⅹ性高电影| 制服丝袜在线91| 久久综合九色综合欧美就去吻| 欧美激情一区三区| 怡红院av一区二区三区| 日韩激情一二三区| 国产精品中文字幕欧美| 91免费观看视频在线| 欧美福利视频导航| 久久免费视频色| 亚洲精品videosex极品| 日韩精品乱码免费| 国产成人午夜高潮毛片| 色哟哟欧美精品| 日韩欧美一区在线| 亚洲国产精品av| 亚洲一区二区三区视频在线播放 | 亚洲图片欧美综合| 激情综合网激情| 一本色道久久综合亚洲91| 欧美猛男男办公室激情| 国产欧美精品国产国产专区 | 久久 天天综合| 91美女蜜桃在线| xfplay精品久久| 亚洲一区在线观看免费| 蜜臀精品久久久久久蜜臀| av激情综合网| 精品久久久网站| 一区二区三区在线播放| 精品一区二区三区欧美| 91成人网在线| 国产蜜臀97一区二区三区| 亚洲国产毛片aaaaa无费看| 国产精品1区二区.| 欧美精品三级日韩久久| 最新成人av在线| 国产一区二区三区黄视频| 欧美在线啊v一区| 国产精品―色哟哟| 久久精品国产色蜜蜜麻豆| 欧美亚洲愉拍一区二区| 国产精品美女一区二区| 久久不见久久见免费视频7| 91福利在线看| 国产精品久久夜| 国产美女在线精品| 日韩午夜av电影| 石原莉奈在线亚洲二区| 一本色道久久综合亚洲aⅴ蜜桃 | 欧美大片在线观看| 亚洲国产精品尤物yw在线观看| 成人a区在线观看| 久久久久亚洲综合| 激情综合色综合久久综合| 4438成人网| 日韩精品五月天| 欧美在线观看禁18| 一区二区三区日本| 色天使色偷偷av一区二区| 国产精品白丝在线| 国产美女精品在线| 久久亚区不卡日本| 久久99精品久久久久婷婷| 欧美挠脚心视频网站| 婷婷中文字幕一区三区| 欧美人妖巨大在线| 天堂久久一区二区三区| 欧美人伦禁忌dvd放荡欲情| 亚洲国产一区二区三区 | 欧美视频一区二区三区四区| 亚洲伦在线观看| 91免费观看视频在线| 亚洲黄色在线视频| 91成人在线精品| 亚洲不卡在线观看| 欧美精品色综合| 蜜臀av一级做a爰片久久| 欧美一区二区人人喊爽| 全国精品久久少妇| 日韩欧美国产一二三区| 午夜伦理一区二区| 欧美一级免费大片| 久久国产人妖系列| 久久这里只有精品首页| 国产精品18久久久久久久久| 久久久久久久久久久电影| 成人av网站在线| 亚洲人一二三区| 欧美揉bbbbb揉bbbbb| 亚洲成人动漫在线观看| 正在播放亚洲一区| 韩国成人精品a∨在线观看| 国产亚洲精品aa| 国产精品人妖ts系列视频| 国产一区二区精品久久| 久久国产精品99精品国产| 一区二区三区色| 国产欧美一区二区三区鸳鸯浴 | 国产一区在线精品| 久久99精品久久久久婷婷| fc2成人免费人成在线观看播放| 国产婷婷一区二区| 一本一道久久a久久精品综合蜜臀| 亚洲午夜在线电影| 日韩久久久精品| 成人午夜视频在线| 亚洲电影视频在线| 久久综合色8888| 91视视频在线观看入口直接观看www| 亚洲国产一区在线观看| 亚洲精品在线观看视频| 亚洲成人动漫在线观看| 一区二区三区在线免费观看| 丝袜美腿高跟呻吟高潮一区| 亚洲午夜精品网| 日韩在线一二三区| 日本久久一区二区| 欧美日韩在线不卡| 亚洲一区二区三区三| 精品久久五月天| 在线观看日韩国产| 成人国产精品免费观看| 精品对白一区国产伦| 亚洲国产视频直播| 在线观看亚洲a| 亚洲精品一区二区在线观看| 欧美一区二区女人| 日韩电影一区二区三区| 国产片一区二区三区| 国产精品一二三四区| 日韩欧美美女一区二区三区| 亚洲女厕所小便bbb| 亚洲福中文字幕伊人影院| 免费看精品久久片| 91美女片黄在线观看91美女| 久久精品人人做| 奇米亚洲午夜久久精品| 成人爱爱电影网址|