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

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

?? ropeimpl.h

?? TSP問題的一個類庫 有源代碼和stl
?? H
?? 第 1 頁 / 共 4 頁
字號:
  template<class _CharT, class _Traits>
  // Here _CharT is both the stream and rope character type.
#else
  template<class _CharT>
  // Here _CharT is the rope character type.  Unlike in the
  // above case, we somewhat handle the case in which it doesn't
  // match the stream character type, i.e. char.
#endif
class _Rope_insert_char_consumer : public _Rope_char_consumer<_CharT> {
    private:
#       ifdef __STL_USE_NEW_IOSTREAMS
	  typedef basic_ostream<_CharT,_Traits> _Insert_ostream;
#	else
	  typedef ostream _Insert_ostream;
#	endif
	_Insert_ostream& _M_o;
    public:
	_Rope_insert_char_consumer(_Insert_ostream& __writer) 
	  : _M_o(__writer) {};
	~_Rope_insert_char_consumer() { };
		// Caller is presumed to own the ostream
	bool operator() (const _CharT* __leaf, size_t __n);
		// Returns true to continue traversal.
};
	    
#ifdef __STL_USE_NEW_IOSTREAMS
  template<class _CharT, class _Traits>
  bool _Rope_insert_char_consumer<_CharT, _Traits>::operator()
                                        (const _CharT* __leaf, size_t __n)
  {
    size_t __i;
    //  We assume that formatting is set up correctly for each element.
    for (__i = 0; __i < __n; __i++) _M_o.put(__leaf[__i]);
    return true;
  }

#else
  template<class _CharT>
  bool _Rope_insert_char_consumer<_CharT>::operator()
					(const _CharT* __leaf, size_t __n)
  {
    size_t __i;
    //  We assume that formatting is set up correctly for each element.
    for (__i = 0; __i < __n; __i++) _M_o << __leaf[__i];
    return true;
  }


  __STL_TEMPLATE_NULL
  inline bool _Rope_insert_char_consumer<char>::operator()
					(const char* __leaf, size_t __n)
  {
    size_t __i;
    for (__i = 0; __i < __n; __i++) _M_o.put(__leaf[__i]);
    return true;
  }
#endif

template <class _CharT, class _Alloc>
bool rope<_CharT, _Alloc>::_S_apply_to_pieces(
				_Rope_char_consumer<_CharT>& __c,
				const _RopeRep* __r,
				size_t __begin, size_t __end)
{
    if (0 == __r) return true;
    switch(__r->_M_tag) {
	case _RopeRep::_S_concat:
	    {
		_RopeConcatenation* __conc = (_RopeConcatenation*)__r;
		_RopeRep* __left =  __conc->_M_left;
		size_t __left_len = __left->_M_size;
		if (__begin < __left_len) {
		    size_t __left_end = min(__left_len, __end);
		    if (!_S_apply_to_pieces(__c, __left, __begin, __left_end))
			return false;
		}
		if (__end > __left_len) {
		    _RopeRep* __right =  __conc->_M_right;
		    size_t __right_start = max(__left_len, __begin);
		    if (!_S_apply_to_pieces(__c, __right,
					 __right_start - __left_len,
					 __end - __left_len)) {
			return false;
		    }
		}
	    }
	    return true;
	case _RopeRep::_S_leaf:
	    {
		_RopeLeaf* __l = (_RopeLeaf*)__r;
		return __c(__l->_M_data + __begin, __end - __begin);
	    }
	case _RopeRep::_S_function:
	case _RopeRep::_S_substringfn:
	    {
		_RopeFunction* __f = (_RopeFunction*)__r;
		size_t __len = __end - __begin;
		bool __result;
		_CharT* __buffer =
		  (_CharT*)alloc::allocate(__len * sizeof(_CharT));
		__STL_TRY {
		  (*(__f->_M_fn))(__begin, __len, __buffer);
		  __result = __c(__buffer, __len);
                  alloc::deallocate(__buffer, __len * sizeof(_CharT));
                }
		__STL_UNWIND((alloc::deallocate(__buffer,
						__len * sizeof(_CharT))))
		return __result;
	    }
	default:
	    __stl_assert(false);
	    /*NOTREACHED*/
	    return false;
    }
}

#ifdef __STL_USE_NEW_IOSTREAMS
  template<class _CharT, class _Traits>
  inline void _Rope_fill(basic_ostream<_CharT, _Traits>& __o, size_t __n)
#else
  inline void _Rope_fill(ostream& __o, size_t __n)
#endif
{
    char __f = __o.fill();
    size_t __i;

    for (__i = 0; __i < __n; __i++) __o.put(__f);
}
    

template <class _CharT> inline bool _Rope_is_simple(_CharT*) { return false; }
inline bool _Rope_is_simple(char*) { return true; }
inline bool _Rope_is_simple(wchar_t*) { return true; }

#ifdef __STL_USE_NEW_IOSTREAMS
  template<class _CharT, class _Traits, class _Alloc>
  basic_ostream<_CharT, _Traits>& operator<<
					(basic_ostream<_CharT, _Traits>& __o,
					 const rope<_CharT, _Alloc>& __r)
#else
  template<class _CharT, class _Alloc>
  ostream& operator<< (ostream& __o, const rope<_CharT, _Alloc>& __r)
#endif
{
    size_t __w = __o.width();
    bool __left = bool(__o.flags() & ios::left);
    size_t __pad_len;
    size_t __rope_len = __r.size();
#   ifdef __STL_USE_NEW_IOSTREAMS
      _Rope_insert_char_consumer<_CharT, _Traits> __c(__o);
#   else
      _Rope_insert_char_consumer<_CharT> __c(__o);
#   endif
    bool __is_simple = _Rope_is_simple((_CharT*)0);
    
    if (__rope_len < __w) {
	__pad_len = __w - __rope_len;
    } else {
	__pad_len = 0;
    }
    if (!__is_simple) __o.width(__w/__rope_len);
    __STL_TRY {
      if (__is_simple && !__left && __pad_len > 0) {
	_Rope_fill(__o, __pad_len);
      }
      __r.apply_to_pieces(0, __r.size(), __c);
      if (__is_simple && __left && __pad_len > 0) {
	_Rope_fill(__o, __pad_len);
      }
      if (!__is_simple)
        __o.width(__w);
    }
    __STL_UNWIND(if (!__is_simple) __o.width(__w))
    return __o;
}

template <class _CharT, class _Alloc>
_CharT*
rope<_CharT,_Alloc>::_S_flatten(_RopeRep* __r,
				 size_t __start, size_t __len,
				 _CharT* __buffer)
{
    _Rope_flatten_char_consumer<_CharT> __c(__buffer);
    _S_apply_to_pieces(__c, __r, __start, __start + __len);
    return(__buffer + __len);
}

template <class _CharT, class _Alloc>
size_t
rope<_CharT,_Alloc>::find(_CharT __pattern, size_t __start) const
{
    _Rope_find_char_char_consumer<_CharT> __c(__pattern);
    _S_apply_to_pieces(__c, _M_tree_ptr, __start, size());
    size_type __result_pos = __start + __c._M_count;
#   ifndef __STL_OLD_ROPE_SEMANTICS
	if (__result_pos == size()) __result_pos = npos;
#   endif
    return __result_pos;
}

template <class _CharT, class _Alloc>
_CharT*
rope<_CharT,_Alloc>::_S_flatten(_RopeRep* __r, _CharT* __buffer)
{
    if (0 == __r) return __buffer;
    switch(__r->_M_tag) {
	case _RopeRep::_S_concat:
	    {
		_RopeConcatenation* __c = (_RopeConcatenation*)__r;
		_RopeRep* __left = __c->_M_left;
		_RopeRep* __right = __c->_M_right;
		_CharT* __rest = _S_flatten(__left, __buffer);
		return _S_flatten(__right, __rest);
	    }
	case _RopeRep::_S_leaf:
	    {
		_RopeLeaf* __l = (_RopeLeaf*)__r;
		return copy_n(__l->_M_data, __l->_M_size, __buffer).second;
	    }
	case _RopeRep::_S_function:
	case _RopeRep::_S_substringfn:
	    // We dont yet do anything with substring nodes.
	    // This needs to be fixed before ropefiles will work well.
	    {
		_RopeFunction* __f = (_RopeFunction*)__r;
		(*(__f->_M_fn))(0, __f->_M_size, __buffer);
		return __buffer + __f->_M_size;
	    }
	default:
	    __stl_assert(false);
	    /*NOTREACHED*/
	    return 0;
    }
}


// This needs work for _CharT != char
template <class _CharT, class _Alloc>
void
rope<_CharT,_Alloc>::_S_dump(_RopeRep* __r, int __indent)
{
    for (int __i = 0; __i < __indent; __i++) putchar(' ');
    if (0 == __r) {
	printf("NULL\n"); return;
    }
    if (_RopeRep::_S_concat == __r->_M_tag) {
	_RopeConcatenation* __c = (_RopeConcatenation*)__r;
	_RopeRep* __left = __c->_M_left;
	_RopeRep* __right = __c->_M_right;

#       ifdef __GC
	  printf("Concatenation %p (depth = %d, len = %ld, %s balanced)\n",
	    __r, __r->_M_depth, __r->_M_size, __r->_M_is_balanced? "" : "not");
#       else
	  printf("Concatenation %p (rc = %ld, depth = %d, "
	           "len = %ld, %s balanced)\n",
		 __r, __r->_M_ref_count, __r->_M_depth, __r->_M_size,
		 __r->_M_is_balanced? "" : "not");
#       endif
	_S_dump(__left, __indent + 2);
	_S_dump(__right, __indent + 2);
	return;
    } else {
	char* __kind;

	switch (__r->_M_tag) {
	    case _RopeRep::_S_leaf:
		__kind = "Leaf";
		break;
	    case _RopeRep::_S_function:
		__kind = "Function";
		break;
	    case _RopeRep::_S_substringfn:
		__kind = "Function representing substring";
		break;
	    default:
		__kind = "(corrupted kind field!)";
	}
#       ifdef __GC
	  printf("%s %p (depth = %d, len = %ld) ",
		 __kind, __r, __r->_M_depth, __r->_M_size);
#       else
	  printf("%s %p (rc = %ld, depth = %d, len = %ld) ",
		 __kind, __r, __r->_M_ref_count, __r->_M_depth, __r->_M_size);
#       endif
	if (_S_is_one_byte_char_type((_CharT*)0)) {
	    const int __max_len = 40;
	    _Self_destruct_ptr __prefix(_S_substring(__r, 0, __max_len));
	    _CharT __buffer[__max_len + 1];
	    bool __too_big = __r->_M_size > __prefix->_M_size;

	    _S_flatten(__prefix, __buffer);
	    __buffer[__prefix->_M_size] = _S_eos((_CharT*)0); 
	    printf("%s%s\n", 
	           (char*)__buffer, __too_big? "...\n" : "\n");
	} else {
	    printf("\n");
	}
    }
}

template <class _CharT, class _Alloc>
const unsigned long
rope<_CharT,_Alloc>::_S_min_len[
  _Rope_RopeRep<_CharT,_Alloc>::_S_max_rope_depth + 1] = {
/* 0 */1, /* 1 */2, /* 2 */3, /* 3 */5, /* 4 */8, /* 5 */13, /* 6 */21,
/* 7 */34, /* 8 */55, /* 9 */89, /* 10 */144, /* 11 */233, /* 12 */377,
/* 13 */610, /* 14 */987, /* 15 */1597, /* 16 */2584, /* 17 */4181,
/* 18 */6765, /* 19 */10946, /* 20 */17711, /* 21 */28657, /* 22 */46368,
/* 23 */75025, /* 24 */121393, /* 25 */196418, /* 26 */317811,
/* 27 */514229, /* 28 */832040, /* 29 */1346269, /* 30 */2178309,
/* 31 */3524578, /* 32 */5702887, /* 33 */9227465, /* 34 */14930352,
/* 35 */24157817, /* 36 */39088169, /* 37 */63245986, /* 38 */102334155,
/* 39 */165580141, /* 40 */267914296, /* 41 */433494437,
/* 42 */701408733, /* 43 */1134903170, /* 44 */1836311903,
/* 45 */2971215073u };
// These are Fibonacci numbers < 2**32.

template <class _CharT, class _Alloc>
rope<_CharT,_Alloc>::_RopeRep*
rope<_CharT,_Alloc>::_S_balance(_RopeRep* __r)
{
    _RopeRep* __forest[_RopeRep::_S_max_rope_depth + 1];
    _RopeRep* __result = 0;
    int __i;
    // Invariant:
    // The concatenation of forest in descending order is equal to __r.
    // __forest[__i]._M_size >= _S_min_len[__i]
    // __forest[__i]._M_depth = __i
    // References from forest are included in refcount.

    for (__i = 0; __i <= _RopeRep::_S_max_rope_depth; ++__i) 
      __forest[__i] = 0;
    __STL_TRY {
      _S_add_to_forest(__r, __forest);
      for (__i = 0; __i <= _RopeRep::_S_max_rope_depth; ++__i) 
        if (0 != __forest[__i]) {
#	ifndef __GC
	  _Self_destruct_ptr __old(__result);
#	endif
	  __result = _S_concat(__forest[__i], __result);
	__forest[__i]->_M_unref_nonnil();
#	if !defined(__GC) && defined(__STL_USE_EXCEPTIONS)
	  __forest[__i] = 0;
#	endif
      }
    }
    __STL_UNWIND(for(__i = 0; __i <= _RopeRep::_S_max_rope_depth; __i++)
		 _S_unref(__forest[__i]))
    if (__result->_M_depth > _RopeRep::_S_max_rope_depth) {
#     ifdef __STL_USE_EXCEPTIONS
	__STL_THROW(length_error("rope too long"));
#     else
	abort();
#     endif
    }
    return(__result);
}


template <class _CharT, class _Alloc>
void
rope<_CharT,_Alloc>::_S_add_to_forest(_RopeRep* __r, _RopeRep** __forest)
{
    if (__r->_M_is_balanced) {
	_S_add_leaf_to_forest(__r, __forest);
	return;
    }
    __stl_assert(__r->_M_tag == _RopeRep::_S_concat);
    {
	_RopeConcatenation* __c = (_RopeConcatenation*)__r;

	_S_add_to_forest(__c->_M_left, __forest);
	_S_add_to_forest(__c->_M_right, __forest);
    }
}


template <class _CharT, class _Alloc>
void
rope<_CharT,_Alloc>::_S_add_leaf_to_forest(_RopeRep* __r, _RopeRep** __forest)
{
    _RopeRep* __insertee;   		// included in refcount
    _RopeRep* __too_tiny = 0;    	// included in refcount
    int __i;  				// forest[0..__i-1] is empty
    size_t __s = __r->_M_size;

    for (__i = 0; __s >= _S_min_len[__i+1]/* not this bucket */; ++__i) {
	if (0 != __forest[__i]) {
#	    ifndef __GC
	      _Self_destruct_ptr __old(__too_tiny);
#	    endif
	    __too_tiny = _S_concat_and_set_balanced(__forest[__i], __too_tiny);
	    __forest[__i]->_M_unref_nonnil();
	    __forest[__i] = 0;
	}
    }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩日日骚| www.视频一区| 亚洲一区电影777| 国产精品色在线观看| 久久夜色精品国产欧美乱极品| 欧美一卡二卡在线| 日韩精品在线看片z| 欧美xingq一区二区| 精品乱码亚洲一区二区不卡| 欧美一区二区三区色| 欧美一区二区精美| xvideos.蜜桃一区二区| 日本一二三四高清不卡| 中文字幕在线一区免费| 亚洲视频免费在线| 一区二区三区毛片| 天天综合网 天天综合色| 日韩精品一级二级| 久久国产欧美日韩精品| 国产精品一区在线观看你懂的| 国产成人精品免费一区二区| bt7086福利一区国产| 欧美视频中文一区二区三区在线观看| 欧美色中文字幕| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 99久久免费视频.com| 一本久久精品一区二区| 欧美精品欧美精品系列| 亚洲精品一区二区三区在线观看| 国产女同性恋一区二区| 一二三区精品视频| 国产电影精品久久禁18| 欧美午夜精品理论片a级按摩| 91精品国产乱| 亚洲欧美中日韩| 三级久久三级久久| 成人午夜碰碰视频| 欧美日本一区二区三区| 中国色在线观看另类| 青娱乐精品视频| av午夜一区麻豆| 精品日韩在线一区| 伊人婷婷欧美激情| 国产精品伊人色| 91麻豆精品国产91久久久更新时间 | 国产精品网站在线播放| 一区二区三区久久久| 国产成人免费在线| 91精选在线观看| 日韩美女视频一区| 国产乱码字幕精品高清av| 一本在线高清不卡dvd| 久久久国产精品午夜一区ai换脸| 亚洲午夜视频在线| 成人毛片视频在线观看| 精品免费国产二区三区| 亚洲r级在线视频| 99精品偷自拍| 日本一区二区三区在线不卡| 蜜桃视频在线观看一区二区| 欧美三区在线视频| 亚洲精品免费在线| www.亚洲国产| 国产精品视频一二三区| 国产一区啦啦啦在线观看| 7777女厕盗摄久久久| 亚洲国产三级在线| 一本久久综合亚洲鲁鲁五月天| 《视频一区视频二区| 成人免费av在线| 中文字幕一区免费在线观看 | 成人av电影在线播放| 欧美国产一区在线| 国产精品乡下勾搭老头1| 久久综合色婷婷| 国产一区二区在线看| 久久五月婷婷丁香社区| 久久电影网站中文字幕| 欧美成人一级视频| 久久国产精品无码网站| 精品国产3级a| 国产麻豆一精品一av一免费| 国产三级精品视频| 成人av网址在线| 亚洲精品国产精品乱码不99| 在线视频观看一区| 天天综合日日夜夜精品| 日韩欧美在线观看一区二区三区| 男人的天堂久久精品| 久久午夜免费电影| 成人免费看视频| 国产精品久99| 欧美日韩国产高清一区二区| 天天射综合影视| 精品美女被调教视频大全网站| 国产99久久久国产精品潘金网站| 中文字幕一区二区在线播放| 一本一本久久a久久精品综合麻豆| 亚洲在线成人精品| 精品久久人人做人人爰| 成人丝袜18视频在线观看| 一区二区三区四区五区视频在线观看 | 欧美日韩中文另类| 久久成人免费网| **性色生活片久久毛片| 3atv在线一区二区三区| 国产精品99久| 亚洲成人av中文| 久久久久久久久久久久电影| 91亚洲精品久久久蜜桃| 日韩高清在线不卡| 国产精品久久久久aaaa樱花| 欧美日韩一区二区三区不卡| 国产在线精品一区二区三区不卡 | 欧美亚洲自拍偷拍| 狠狠色狠狠色综合日日91app| 亚洲少妇30p| 久久午夜色播影院免费高清 | 高清不卡一二三区| 日韩精品电影在线| 国产精品久久久久一区二区三区| 91精品久久久久久久久99蜜臂 | 亚洲国产精品一区二区久久| 日韩一级二级三级精品视频| 色综合久久久久网| 国产盗摄一区二区三区| 日本成人在线网站| 一区二区三区 在线观看视频| 久久亚洲免费视频| 欧美高清一级片在线| av电影在线观看不卡| 国产一区二区电影| 青青草91视频| 午夜激情久久久| 国产精品久久久久永久免费观看 | 精品1区2区3区| av中文字幕不卡| 懂色av中文一区二区三区| 美女一区二区视频| 午夜成人免费视频| 亚洲一区日韩精品中文字幕| 1024亚洲合集| 亚洲日本欧美天堂| 国产精品网站一区| 国产精品三级电影| 亚洲国产经典视频| 欧美激情一区三区| 国产日韩欧美精品综合| 精品国产免费一区二区三区香蕉| 欧美日韩视频第一区| 欧美色综合网站| 欧美蜜桃一区二区三区| 精品视频123区在线观看| 欧美三区免费完整视频在线观看| 91小视频在线| 91香蕉国产在线观看软件| 91社区在线播放| 色噜噜久久综合| 在线一区二区三区四区五区 | 欧美又粗又大又爽| 欧美午夜精品一区二区三区| 在线观看日韩一区| 欧美乱妇一区二区三区不卡视频| 欧美日韩激情一区二区| 日韩一区二区三区免费观看| 日韩欧美黄色影院| 久久综合五月天婷婷伊人| 久久久久国产精品厨房| 国产欧美日韩不卡免费| 男女男精品视频网| 蓝色福利精品导航| 国产一区二区毛片| 91玉足脚交白嫩脚丫在线播放| 91在线视频网址| 欧美精品一卡两卡| 久久久蜜桃精品| 中文字幕一区二区在线观看| 亚洲一区二区三区四区在线观看 | 亚洲天堂成人在线观看| 一区二区三区日韩欧美| 无吗不卡中文字幕| 国模套图日韩精品一区二区| 成人三级在线视频| 欧美日韩亚洲另类| 久久众筹精品私拍模特| 亚洲欧美色一区| 日韩成人精品视频| 不卡在线视频中文字幕| 7777精品伊人久久久大香线蕉完整版 | 色综合久久久久久久久| 精品少妇一区二区三区视频免付费 | 国产精品欧美久久久久一区二区| 亚洲综合在线电影| 国产一区二区视频在线播放| 99久久婷婷国产综合精品电影| 欧美一区二区视频观看视频| 综合在线观看色| 国产在线精品一区二区夜色| 欧美在线视频不卡| 欧美激情一区不卡|