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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? stl_bitset.c

?? 粗慥集成算法集合 ,并有詳細(xì)的文檔資料和測(cè)試數(shù)據(jù)處
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*
 * Copyright (c) 1998
 * Silicon Graphics Computer Systems, Inc.
 *
 * 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_BITSET_C
# define  __STL_BITSET_C

#define __BITS_PER_WORDT(__wt) (CHAR_BIT*sizeof(__wt))
#define __BITSET_WORDS(__n,__wt) \
 ((__n) < 1 ? 1 : ((__n) + __BITS_PER_WORDT(__wt) - 1)/__BITS_PER_WORDT(__wt))

# if ! defined (__STL_DEFAULT_TYPE_PARAM)
#  define bitset __bitset
# endif

#if defined(__IBMCPP__)
// supress EDC3130: A constant is being used as a conditional expression
#pragma info(nocnd) 
#endif

__STL_BEGIN_NAMESPACE

//
// Definitions of non-inline functions from _Base_bitset.
// 

template<size_t _Nw, class _WordT>
_Base_bitset<_Nw, _WordT>::_Base_bitset(unsigned long __val)
{
  _M_do_reset();
  const size_t __n = min(sizeof(unsigned long)*CHAR_BIT,
                         __BITS_PER_WORDT(_WordT)*_Nw);
  for(size_t __i = 0; __i < __n; ++__i, __val >>= 1)
    if ( __val & 0x1 )
      _M_getword(__i) |= _S_maskbit(__i);
}

template<size_t _Nw, class _WordT>
void _Base_bitset<_Nw, _WordT>::_M_do_left_shift(size_t __shift) 
{
  if (__shift != 0) {
    const size_t __wshift = __shift / __BITS_PER_WORDT(_WordT);
    const size_t __offset = __shift % __BITS_PER_WORDT(_WordT);
    const size_t __sub_offset = __BITS_PER_WORDT(_WordT) - __offset;
    size_t __n = _Nw - 1;
    for ( ; __n > __wshift; --__n)
      _M_w[__n] = (_M_w[__n - __wshift] << __offset) | 
                (_M_w[__n - __wshift - 1] >> __sub_offset);
    if (__n == __wshift)
      _M_w[__n] = _M_w[0] << __offset;
    for (size_t __n1 = 0; __n1 < __n; ++__n1)
      _M_w[__n1] = __STATIC_CAST(_WordT,0);
  }
}

template<size_t _Nw, class _WordT>
void _Base_bitset<_Nw, _WordT>::_M_do_right_shift(size_t __shift) 
{
  if (__shift != 0) {
    const size_t __wshift = __shift / __BITS_PER_WORDT(_WordT);
    const size_t __offset = __shift % __BITS_PER_WORDT(_WordT);
    const size_t __sub_offset = __BITS_PER_WORDT(_WordT) - __offset;
    const size_t __limit = _Nw - __wshift - 1;
    size_t __n = 0;
    for ( ; __n < __limit; ++__n)
      _M_w[__n] = (_M_w[__n + __wshift] >> __offset) | 
                  (_M_w[__n + __wshift + 1] << __sub_offset);
    _M_w[__limit] = _M_w[_Nw-1] >> __offset;
    for (size_t __n1 = __limit + 1; __n1 < _Nw; ++__n1)
      _M_w[__n1] = __STATIC_CAST(_WordT,0);
  }
}

template<size_t _Nw, class _WordT>
unsigned long _Base_bitset<_Nw, _WordT>::_M_do_to_ulong() const
{
  if (sizeof(_WordT) >= sizeof(unsigned long)) {
    for (size_t __i = 1; __i < _Nw; ++__i) 
      if (_M_w[__i]) 
        __STL_THROW(overflow_error("bitset"));

    const _WordT __mask = __STATIC_CAST(_WordT,__STATIC_CAST(unsigned long,-1));
    if (_M_w[0] & ~__mask) 
      __STL_THROW(overflow_error("bitset"));


    return __STATIC_CAST(unsigned long,_M_w[0] & __mask);
  }
  else {                      // sizeof(_WordT) < sizeof(unsigned long).
    const size_t __nwords =
      (sizeof(unsigned long) + sizeof(_WordT) - 1) / sizeof(_WordT);

    size_t __min_nwords = __nwords;
    if (_Nw > __nwords) {
      for (size_t __i = __nwords; __i < _Nw; ++__i) 
        if (_M_w[__i]) 
	  __STL_THROW(overflow_error("bitset"));
    }
    else 
      __min_nwords = _Nw;
      
    // If unsigned long is 8 bytes and _WordT is 6 bytes, then an unsigned
    // long consists of all of one word plus 2 bytes from another word.
    const size_t __part = sizeof(unsigned long) % sizeof(_WordT);

    if (__part != 0 && __nwords <= _Nw && 
        (_M_w[__min_nwords - 1] >> ((sizeof(_WordT) - __part) * CHAR_BIT)) != 0)
      __STL_THROW(overflow_error("bitset"));

    unsigned long __result = 0;
    for (size_t __i = 0; __i < __min_nwords; ++__i) {
      __result |= __STATIC_CAST(const unsigned long,
         _M_w[__i]) << (__i * sizeof(_WordT) * CHAR_BIT);
    }
    return __result;
  }
} // End _M_do_to_ulong

template<size_t _Nw, class _WordT>
size_t _Base_bitset<_Nw, _WordT>::_M_do_find_first(size_t __not_found) const 
{
  for ( size_t __i = 0; __i < _Nw; __i++ ) {
    _WordT __thisword = _M_w[__i];
    if ( __thisword != __STATIC_CAST(_WordT,0) ) {
      // find byte within word
      for ( size_t __j = 0; __j < sizeof(_WordT); __j++ ) {
        unsigned char __this_byte
          = __STATIC_CAST(unsigned char,(__thisword & (~(unsigned char)0)));
        if ( __this_byte )
          return __i*__BITS_PER_WORDT(_WordT) + __j*CHAR_BIT +
            _First_one<true>::_S_first_one[__this_byte];

        __thisword >>= CHAR_BIT;
      }
    }
  }
  // not found, so return an indication of failure.
  return __not_found;
}

template<size_t _Nw, class _WordT>
size_t
_Base_bitset<_Nw, _WordT>::_M_do_find_next(size_t __prev, 
                                           size_t __not_found) const
{
  // make bound inclusive
  ++__prev;

  // check out of bounds
  if ( __prev >= _Nw * __BITS_PER_WORDT(_WordT) )
    return __not_found;

    // search first word
  size_t __i = _S_whichword(__prev);
  _WordT __thisword = _M_w[__i];

    // mask off bits below bound
  __thisword &= (~__STATIC_CAST(_WordT,0)) << _S_whichbit(__prev);

  if ( __thisword != __STATIC_CAST(_WordT,0) ) {
    // find byte within word
    // get first byte into place
    __thisword >>= _S_whichbyte(__prev) * CHAR_BIT;
    for ( size_t __j = _S_whichbyte(__prev); __j < sizeof(_WordT); __j++ ) {
      unsigned char __this_byte
        = __STATIC_CAST(unsigned char,(__thisword & (~(unsigned char)0)));
      if ( __this_byte )
        return __i*__BITS_PER_WORDT(_WordT) + __j*CHAR_BIT +
          _First_one<true>::_S_first_one[__this_byte];

      __thisword >>= CHAR_BIT;
    }
  }

  // check subsequent words
  __i++;
  for ( ; __i < _Nw; __i++ ) {
    _WordT __thisword = _M_w[__i];
    if ( __thisword != __STATIC_CAST(_WordT,0) ) {
      // find byte within word
      for ( size_t __j = 0; __j < sizeof(_WordT); __j++ ) {
        unsigned char __this_byte
          = __STATIC_CAST(unsigned char,(__thisword & (~(unsigned char)0)));
        if ( __this_byte )
          return __i*__BITS_PER_WORDT(_WordT) + __j*CHAR_BIT +
            _First_one<true>::_S_first_one[__this_byte];

        __thisword >>= CHAR_BIT;
      }
    }
  }

  // not found, so return an indication of failure.
  return __not_found;
} // end _M_do_find_next


// ------------------------------------------------------------
//
// Definitions of non-inline functions from the single-word version of
//  _Base_bitset.
//

# if defined (__STL_CLASS_PARTIAL_SPECIALIZATION)

template <class _WordT>
size_t _Base_bitset<1, _WordT>::_M_do_find_first(size_t __not_found) const
{
  _WordT __thisword = _M_w;

  if ( __thisword != __STATIC_CAST(_WordT,0) ) {
    // find byte within word
    for ( size_t __j = 0; __j < sizeof(_WordT); __j++ ) {
      unsigned char __this_byte
        = __STATIC_CAST(unsigned char,(__thisword & (~(unsigned char)0)));
      if ( __this_byte )
        return __j*CHAR_BIT + _First_one<true>::_S_first_one[__this_byte];

      __thisword >>= CHAR_BIT;
    }
  }
  // not found, so return a value that indicates failure.
  return __not_found;
}

template <class _WordT>
size_t 
_Base_bitset<1, _WordT>::_M_do_find_next(size_t __prev, 
                                         size_t __not_found ) const
{
  // make bound inclusive
  ++__prev;

  // check out of bounds
  if ( __prev >= __BITS_PER_WORDT(_WordT) )
    return __not_found;

    // search first (and only) word
  _WordT __thisword = _M_w;

  // mask off bits below bound
  __thisword &= (~__STATIC_CAST(_WordT,0)) << _S_whichbit(__prev);

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
男人的天堂久久精品| 国产在线国偷精品产拍免费yy | 国产乱理伦片在线观看夜一区| 中文字幕乱码亚洲精品一区 | 日韩一区二区三区av| 波多野结衣中文字幕一区| 日韩电影一区二区三区| 亚洲日本va在线观看| 久久久久国产精品免费免费搜索| 91国内精品野花午夜精品| 风流少妇一区二区| 极品少妇xxxx精品少妇偷拍| 亚洲国产精品一区二区久久 | 免费一级片91| 亚洲成av人片一区二区梦乃| 国产精品久久久久久久裸模| 日韩精品一区二区三区在线播放| 欧美日韩黄视频| 色噜噜狠狠成人中文综合| 成人黄色在线看| 国产精品18久久久久| 蜜臀av一区二区| 日本伊人色综合网| 亚洲国产精品精华液网站| 亚洲免费大片在线观看| 亚洲视频一二三区| 中文字幕亚洲一区二区av在线| 久久久久久亚洲综合影院红桃 | 精品福利一二区| 国产亚洲欧美色| 精品国产一区二区三区忘忧草| 欧美精品一二三四| 欧美亚洲国产bt| 欧美性受xxxx黑人xyx性爽| 色综合天天综合| 91看片淫黄大片一级| 99re热视频这里只精品| 97精品国产露脸对白| 91色|porny| 欧美专区在线观看一区| 欧美在线观看视频一区二区三区| 色婷婷精品久久二区二区蜜臀av| 色综合久久精品| 欧美性受xxxx| 91精品国产aⅴ一区二区| 欧美一二区视频| 精品国产sm最大网站| 久久先锋影音av| 国产欧美一区二区三区在线看蜜臀 | 91亚洲大成网污www| 99re8在线精品视频免费播放| 91在线国内视频| 欧美亚洲尤物久久| 欧美一区二区三区性视频| 日韩免费视频一区二区| 国产亚洲va综合人人澡精品| 国产精品麻豆欧美日韩ww| 伊人夜夜躁av伊人久久| 日韩中文字幕不卡| 国产一区二区三区四区五区入口 | 欧美精品第1页| 26uuu精品一区二区在线观看| 亚洲国产精品传媒在线观看| 伊人婷婷欧美激情| 久久99久久久久| 成人午夜激情视频| 91国产免费看| 精品国产伦理网| 综合欧美一区二区三区| 三级在线观看一区二区| 国产在线精品一区二区夜色| 成人av影视在线观看| 欧美午夜寂寞影院| 久久影院电视剧免费观看| 中文字幕在线观看一区| 亚洲成人精品一区| 国产福利91精品一区| 91极品视觉盛宴| 久久亚洲二区三区| 亚洲一区二区三区在线看| 狠狠色丁香久久婷婷综合_中| 99精品偷自拍| 欧美va在线播放| 亚洲最快最全在线视频| 国产福利一区二区三区在线视频| 欧美在线观看视频一区二区三区| 久久一区二区三区四区| 亚洲福利国产精品| 国产成人精品www牛牛影视| 欧美日韩国产一区| 国产精品伦一区| 久久精品免费观看| 在线看国产一区二区| 国产日产欧产精品推荐色| 丝袜亚洲另类欧美| 91首页免费视频| 久久久亚洲午夜电影| 日本午夜精品视频在线观看| 91偷拍与自偷拍精品| 久久新电视剧免费观看| 天天综合天天做天天综合| 99精品国产热久久91蜜凸| 亚洲精品一线二线三线无人区| 午夜精品一区二区三区免费视频 | 欧美疯狂做受xxxx富婆| 亚洲视频电影在线| 懂色av中文一区二区三区| 欧美本精品男人aⅴ天堂| 亚洲一区二区三区爽爽爽爽爽| 成人动漫一区二区在线| wwwwww.欧美系列| 麻豆精品蜜桃视频网站| 欧美日韩国产免费一区二区| 亚洲免费观看高清在线观看| 国产精品自产自拍| 久久综合久久鬼色中文字| 日本欧美一区二区三区乱码 | 欧美一区二区三区视频免费| 亚洲精品午夜久久久| a级精品国产片在线观看| 国产欧美日韩在线视频| 精品一区二区三区在线播放| 7777精品伊人久久久大香线蕉的| 一区二区三区精品在线| 91农村精品一区二区在线| 国产精品大尺度| 99久久99久久久精品齐齐| 国产精品高潮呻吟久久| 大尺度一区二区| 国产精品―色哟哟| www.亚洲国产| 中文字幕在线不卡一区| 99re免费视频精品全部| 亚洲欧洲三级电影| 色综合天天综合网国产成人综合天| 日本一区二区久久| 99视频精品免费视频| 综合av第一页| 在线观看日韩国产| 天堂在线一区二区| 91精品国产高清一区二区三区| 麻豆国产欧美日韩综合精品二区| 日韩一区二区在线看片| 国产在线不卡视频| 国产精品你懂的| 91欧美一区二区| 亚洲成人黄色小说| 欧美一区二区啪啪| 国产九色sp调教91| 国产精品久久网站| 色琪琪一区二区三区亚洲区| 亚洲一区二区3| 91精品国产一区二区三区蜜臀 | 亚洲精品成人在线| 欧美午夜精品理论片a级按摩| 亚洲成av人**亚洲成av**| 91精品国产全国免费观看| 狠狠色丁香久久婷婷综| 日本一区二区久久| 欧美在线免费播放| 激情综合网最新| 最新国产精品久久精品| 精品视频一区二区三区免费| 全国精品久久少妇| 国产精品美女久久久久高潮| 欧洲精品在线观看| 久久99精品久久久久婷婷| 欧美激情一区三区| 欧美日韩另类一区| 国产精品一区2区| 亚洲永久免费av| 2021中文字幕一区亚洲| 色综合天天在线| 极品瑜伽女神91| **网站欧美大片在线观看| 欧美一区二区三区系列电影| 成人一区二区三区视频在线观看| 亚洲精选视频在线| 久久免费精品国产久精品久久久久| 日韩免费高清视频| 99久久精品情趣| 麻豆视频观看网址久久| 国产精品国产自产拍高清av| 在线电影国产精品| 99久久免费精品高清特色大片| 日韩精品一级中文字幕精品视频免费观看 | 国产剧情一区二区三区| 亚洲视频每日更新| 26uuu色噜噜精品一区二区| 91久久精品一区二区二区| 国产伦精品一区二区三区免费迷 | 色94色欧美sute亚洲线路二| 麻豆中文一区二区| 日韩美女视频一区| 日韩视频一区二区三区在线播放| 91在线免费视频观看| 国产伦精品一区二区三区视频青涩 | 成人免费精品视频| 精品在线一区二区三区| 亚洲亚洲人成综合网络|