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

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

?? stl_vector.c

?? 粗慥集成算法集合 ,并有詳細(xì)的文檔資料和測(cè)試數(shù)據(jù)處
?? C
字號(hào):
/*
 *
 *
 * 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_VECTOR_C
#define __STL_VECTOR_C

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

#  undef  vector
#  define vector __WORKAROUND_RENAME(vector)

# if defined ( __STL_NESTED_TYPE_PARAM_BUG )
#  define __pointer__             _Tp*
#  define __const_pointer__       const _Tp*
#  define __size_type__           size_t
#  define __difference_type__     ptrdiff_t
# else
#  define __pointer__         pointer
#  define __const_pointer__   const_pointer
#  define __size_type__       size_type
#  define __difference_type__ difference_type
# endif

# undef _Make_ptr
# if defined (__STL_DEBUG)
#  define _Make_iterator(__i) iterator(&_M_iter_list, __i)
#  define _Make_const_iterator(__i) const_iterator(&_M_iter_list, __i)
#  define _Make_ptr(__i)   __i._M_iterator
#  define __iterator__       _Vec_iter<_Tp, _Nonconst_traits<_Tp> >
#  define __const_iterator__ _Vec_iter<_Tp, _Const_traits<_Tp> >
# else
#  define __iterator__       __pointer__
#  define __const_iterator__ __const_pointer__  
#  define _Make_iterator(__i) __i
#  define _Make_const_iterator(__i) __i
#  define _Make_ptr(__i)   __i
# endif

__STL_BEGIN_NAMESPACE

template <class _Tp, class _Alloc>
void 
vector<_Tp, _Alloc>::reserve(__size_type__ __n) {
  if (capacity() < __n) {
    const size_type __old_size = size();
    pointer __tmp;
    if (_M_start) {
      __tmp = _M_allocate_and_copy(__n, _M_start, _M_finish);
      __STLPORT_STD::destroy(_M_start, _M_finish);
      _M_end_of_storage.deallocate(_M_start, _M_end_of_storage._M_data - _M_start);
     } else {
      __tmp = _M_end_of_storage.allocate(__n);
    }
    _M_start = __tmp;
    _M_finish = __tmp + __old_size;
    _M_end_of_storage._M_data = _M_start + __n;
  }
}

#if defined (__STL_MEMBER_TEMPLATES) && ! defined (__STL_INLINE_MEMBER_TEMPLATES)

template <class _Tp, class _Alloc>  template <class _ForwardIter>
void 
vector<_Tp, _Alloc>::_M_assign_aux(_ForwardIter __first, _ForwardIter __last,
				   forward_iterator_tag) {
  size_type __len = 0;
  distance(__first, __last, __len);
    
  if (__len > capacity()) {
    iterator __tmp = _M_allocate_and_copy(__len, __first, __last);
    __STLPORT_STD::destroy(_M_start, _M_finish);
    _M_end_of_storage.deallocate(_M_start, _M_end_of_storage._M_data - _M_start);
    _M_start = __tmp;
    _M_end_of_storage._M_data = _M_finish = _M_start + __len;
  }
  else if (size() >= __len) {
    iterator __new_finish = copy(__first, __last, _M_start);
    __STLPORT_STD::destroy(__new_finish, _M_finish);
    _M_finish = __new_finish;
  }
  else {
    _ForwardIter __mid = __first;
    advance(__mid, size());
    copy(__first, __mid, _M_start);
    _M_finish = uninitialized_copy(__mid, __last, _M_finish);
  }
}

template <class _Tp, class _Alloc> template <class _ForwardIterator>
void  vector<_Tp, _Alloc>::_M_range_insert(
# ifdef __STL_DEBUG
					   __iterator__ __pos,
# else
					   __iterator__ __position,
# endif
					   _ForwardIterator __first,
					   _ForwardIterator __last,
					   forward_iterator_tag) {
      
#ifdef __STL_DEBUG
  __stl_debug_check(__check_if_owner(&_M_iter_list, __pos));
  pointer __position(_Make_ptr(__pos));
#endif
  if (__first != __last) {
    __stl_debug_check(__check_range(__first,__last));
    size_type __n = 0;
    distance(__first, __last, __n);
    if (size_type(_M_end_of_storage._M_data - _M_finish) >= __n) {
      const size_type __elems_after = _M_finish - __position;
      pointer __old_finish = _M_finish;
      if (__elems_after > __n) {
	uninitialized_copy(_M_finish - __n, _M_finish, _M_finish);
	_M_finish += __n;
	copy_backward(__position, __old_finish - __n, __old_finish);
	copy(__first, __last, __position);
      }
      else {
	_ForwardIterator __mid = __first;
	advance(__mid, __elems_after);
	uninitialized_copy(__mid, __last, _M_finish);
	_M_finish += __n - __elems_after;
	uninitialized_copy(__position, __old_finish, _M_finish);
	_M_finish += __elems_after;
	copy(__first, __mid, __position);
      }
      __stl_debug_do(__invalidate_range(&_M_iter_list, __pos, end()));
    }
    else {
      const size_type __old_size = size();
      const size_type __len = __old_size + max(__old_size, __n);
      pointer __new_start = _M_end_of_storage.allocate(__len);
      pointer __new_finish = __new_start;
      __STL_TRY {
	__new_finish = uninitialized_copy(_M_start, __position, __new_start);
	__new_finish = uninitialized_copy(__first, __last, __new_finish);
	__new_finish
	  = uninitialized_copy(__position, _M_finish, __new_finish);
      }
      __STL_UNWIND((__STLPORT_STD::destroy(__new_start,__new_finish), 
		    _M_end_of_storage.deallocate(__new_start,__len)));
      __STLPORT_STD::destroy(_M_start, _M_finish);
      _M_end_of_storage.deallocate(_M_start, _M_end_of_storage._M_data - _M_start);
      _M_start = __new_start;
      _M_finish = __new_finish;
      _M_end_of_storage._M_data = __new_start + __len;
    }
  }
}

#endif /* __STL_MEMBER_TEMPLATES */


template <class _Tp, class _Alloc>
vector<_Tp,_Alloc>& 
vector<_Tp,_Alloc>::operator=(const vector<_Tp, _Alloc>& __x)
{
  if (&__x != this) {
    const size_type __xlen = __x.size();
    __stl_debug_do(_M_iter_list._Invalidate_all());
    if (__xlen > capacity()) {
      pointer __tmp = _M_allocate_and_copy(__xlen, (const_pointer)__x._M_start+0, (const_pointer)__x._M_finish+0);
      __STLPORT_STD::destroy(_M_start, _M_finish);
      _M_end_of_storage.deallocate(_M_start, _M_end_of_storage._M_data - _M_start);
      _M_start = __tmp;
      _M_end_of_storage._M_data = _M_start + __xlen;
    }
    else if (size() >= __xlen) {
      pointer __i = copy((const_pointer)__x._M_start+0, (const_pointer)__x._M_finish+0, _M_start);
      __STLPORT_STD::destroy(__i, _M_finish);
    }
    else {
      copy((const_pointer)__x._M_start, (const_pointer)__x._M_start + size(), _M_start);
      uninitialized_copy((const_pointer)__x._M_start + size(), (const_pointer)__x._M_finish+0, _M_finish);
    }
    _M_finish = _M_start + __xlen;
  }
  return *this;
}

template <class _Tp, class _Alloc>
void vector<_Tp, _Alloc>::_M_fill_assign(size_t __n, const _Tp& __val) {
  if (__n > capacity()) {
    vector<_Tp, _Alloc> __tmp(__n, __val, get_allocator());
    __tmp.swap(*this);
  }
  else if (__n > size()) {
    fill(begin(), end(), __val);
    _M_finish = uninitialized_fill_n(_M_finish, __n - size(), __val);
  }
  else
    erase(fill_n(begin(), __n, __val), end());
}

template <class _Tp, class _Alloc>
void 
vector<_Tp, _Alloc>::_M_insert_aux(_Tp* __position, const _Tp& __x)
{
  if (_M_finish != _M_end_of_storage._M_data) {
    __STLPORT_STD::construct(_M_finish, *(_M_finish - 1));
    ++_M_finish;
    _Tp __x_copy = __x;
    copy_backward(__position, _M_finish - 2, _M_finish - 1);
    *__position = __x_copy;
  }
  else {
    const size_type __old_size = size();
    const size_type __len = __old_size != 0 ? 2 * __old_size : 1;
    pointer __new_start = _M_end_of_storage.allocate(__len);
    pointer __new_finish = __new_start;
    __STL_TRY {
      __new_finish = uninitialized_copy(_M_start, __position, __new_start);
      __STLPORT_STD::construct(__new_finish, __x);
      ++__new_finish;
      __new_finish = uninitialized_copy(__position, _M_finish, __new_finish);
    }
    __STL_UNWIND((__STLPORT_STD::destroy(__new_start,__new_finish), 
		  _M_end_of_storage.deallocate(__new_start,__len)));
    __STLPORT_STD::destroy(_M_start, _M_finish);
    _M_end_of_storage.deallocate(_M_start, _M_end_of_storage._M_data - _M_start);
    _M_start = __new_start;
    _M_finish = __new_finish;
    _M_end_of_storage._M_data = __new_start + __len;
  }
}

template <class _Tp, class _Alloc>
void 
vector<_Tp, _Alloc>::_M_insert_aux(_Tp* __position)
{
  if (_M_finish != _M_end_of_storage._M_data) {
    __STLPORT_STD::construct(_M_finish, *(_M_finish - 1));
    ++_M_finish;
    copy_backward(__position, _M_finish - 2, _M_finish - 1);
    *__position = _Tp();
  }
  else {
    const size_type __old_size = size();
    const size_type __len = __old_size != 0 ? 2 * __old_size : 1;
    pointer __new_start = _M_end_of_storage.allocate(__len);
    pointer __new_finish = __new_start;
    __STL_TRY {
      __new_finish = uninitialized_copy(_M_start, __position, __new_start);
      __STLPORT_STD::construct(__new_finish);
      ++__new_finish;
      __new_finish = uninitialized_copy(__position, _M_finish, __new_finish);
    }
    __STL_UNWIND((__STLPORT_STD::destroy(__new_start,__new_finish), 
		  _M_end_of_storage.deallocate(__new_start,__len)));
    __STLPORT_STD::destroy(begin(), end());
    _M_end_of_storage.deallocate(_M_start, _M_end_of_storage._M_data - _M_start);
    _M_start = __new_start;
    _M_finish = __new_finish;
    _M_end_of_storage._M_data = __new_start + __len;
  }
}

template <class _Tp, class _Alloc>
void 
vector<_Tp, _Alloc>::_M_fill_insert(
# if defined ( __STL_DEBUG )
				    __iterator__ __pos, 
# else
				    __iterator__ __position, 
# endif
				    __size_type__ __n, const _Tp& __x) {
# if defined ( __STL_DEBUG )
  __stl_debug_check(__check_if_owner(&_M_iter_list, __pos));
  pointer __position=_Make_ptr(__pos);
# endif
  if (__n != 0) {
    if (size_type(_M_end_of_storage._M_data - _M_finish) >= __n) {
      _Tp __x_copy = __x;
      const size_type __elems_after = _M_finish - __position;
      pointer __old_finish = _M_finish;
      if (__elems_after > __n) {
	uninitialized_copy(_M_finish - __n, _M_finish, _M_finish);
	_M_finish += __n;
	copy_backward(__position, __old_finish - __n, __old_finish);
	fill(__position, __position + __n, __x_copy);
      }
      else {
	uninitialized_fill_n(_M_finish, __n - __elems_after, __x_copy);
	_M_finish += __n - __elems_after;
	uninitialized_copy(__position, __old_finish, _M_finish);
	_M_finish += __elems_after;
	fill(__position, __old_finish, __x_copy);
      }
      __stl_debug_do(__invalidate_range(&_M_iter_list, __pos, end()));
    }
    else {
      const size_type __old_size = size();        
      const size_type __len = __old_size + max(__old_size, __n);
      pointer __new_start = _M_end_of_storage.allocate(__len);
      pointer __new_finish = __new_start;
      __STL_TRY {
	__new_finish = uninitialized_copy(_M_start, __position, __new_start);
	__new_finish = uninitialized_fill_n(__new_finish, __n, __x);
	__new_finish
	  = uninitialized_copy(__position, _M_finish, __new_finish);
      }
      __STL_UNWIND((__STLPORT_STD::destroy(__new_start,__new_finish), 
		    _M_end_of_storage.deallocate(__new_start,__len)));
      __STLPORT_STD::destroy(_M_start, _M_finish);
      _M_end_of_storage.deallocate(_M_start, _M_end_of_storage._M_data - _M_start);
      _M_start = __new_start;
      _M_finish = __new_finish;
      _M_end_of_storage._M_data = __new_start + __len;
    }
  }
}

#ifndef __STL_MEMBER_TEMPLATES

template <class _Tp, class _Alloc>
void 
vector<_Tp, _Alloc>::insert(
# if defined ( __STL_DEBUG )
			    __iterator__ __pos, 
			    __const_pointer__ __first, 
			    __const_pointer__ __last
# else
			    __iterator__ __position, 
			    __const_iterator__ __first, 
			    __const_iterator__ __last
# endif
			    ) {
# if defined ( __STL_DEBUG )
  __stl_debug_check(__check_if_owner(&_M_iter_list, __pos));
  pointer __position=_Make_ptr(__pos);
# endif
  if (__first != __last) {
    size_type __n = 0;
    distance(__first, __last, __n);
    if (size_type(_M_end_of_storage._M_data - _M_finish) >= __n) {
      const size_type __elems_after = _M_finish - __position;
      pointer __old_finish = _M_finish;
      if (__elems_after > __n) {
	uninitialized_copy(_M_finish - __n, _M_finish, _M_finish);
	_M_finish += __n;
	copy_backward(__position, __old_finish - __n, __old_finish);
	copy(__first, __last, __position);
      }
      else {
	uninitialized_copy(__first + __elems_after, __last, _M_finish);
	_M_finish += __n - __elems_after;
	uninitialized_copy(__position, __old_finish, _M_finish);
	_M_finish += __elems_after;
	copy(__first, __first + __elems_after, __position);
      }
      __stl_debug_do(__invalidate_range(&_M_iter_list, __pos, end()));
    }
    else {
      const size_type __old_size = size();
      const size_type __len = __old_size + max(__old_size, __n);
      pointer __new_start = _M_end_of_storage.allocate(__len);
      pointer __new_finish = __new_start;
      __STL_TRY {
	__new_finish = uninitialized_copy(_M_start, __position, __new_start);
	__new_finish = uninitialized_copy(__first, __last, __new_finish);
	__new_finish = uninitialized_copy(__position, _M_finish, __new_finish);
      }
      __STL_UNWIND((__STLPORT_STD::destroy(__new_start,__new_finish),
		    _M_end_of_storage.deallocate(__new_start,__len)));
      __STLPORT_STD::destroy(_M_start, _M_finish);
      _M_end_of_storage.deallocate(_M_start, _M_end_of_storage._M_data - _M_start);
      _M_start = __new_start;
      _M_finish = __new_finish;
      _M_end_of_storage._M_data = __new_start + __len;
    }
  }
}

#endif /* __STL_MEMBER_TEMPLATES */

__STL_END_NAMESPACE

# undef vector

# undef __pointer__
# undef __const_pointer__
# undef __size_type__
# undef __difference_type__
# undef _Make_iterator
# undef _Make_const_iterator
# undef _Make_ptr
# undef __iterator__
# undef __const_iterator__

#endif /*  __STL_VECTOR_C */

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

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕在线一区免费| 亚洲色图20p| 91色九色蝌蚪| 麻豆成人免费电影| 伊人开心综合网| 中文字幕不卡的av| 日韩一区二区高清| 欧美伊人久久大香线蕉综合69| 国产成人免费在线| 免费高清在线一区| 亚洲午夜在线电影| 亚洲视频一区在线| 国产欧美一区二区精品忘忧草 | 亚洲日本在线观看| 久久众筹精品私拍模特| 欧美一区二区三区视频在线 | 3d动漫精品啪啪| 99精品1区2区| av一区二区久久| 国产成人精品亚洲777人妖| 久久99久久久久久久久久久| 亚洲第一福利视频在线| 亚洲人成影院在线观看| 国产精品情趣视频| 国产亚洲综合在线| 国产亚洲精品bt天堂精选| 26uuu亚洲综合色欧美| 日韩精品一区二区三区在线观看 | 精品国产伦一区二区三区观看方式 | 欧美一区永久视频免费观看| 91九色02白丝porn| 91无套直看片红桃| 91日韩精品一区| 97国产精品videossex| www.亚洲人| 91网上在线视频| 91黄色激情网站| 欧美午夜免费电影| 欧美精品一二三| 91麻豆精品国产91久久久更新时间 | 日本高清不卡一区| 欧美在线看片a免费观看| 在线免费观看一区| 欧美肥胖老妇做爰| 91精品国产日韩91久久久久久| 欧美一级片在线看| 日韩精品一区二区三区视频在线观看| 欧美妇女性影城| 日韩欧美一卡二卡| 精品福利一区二区三区免费视频| 精品久久久久久久久久久久久久久| 日韩欧美一二三四区| 精品国产网站在线观看| 国产午夜精品美女毛片视频| 国产精品久久777777| 亚洲美女屁股眼交| 五月婷婷另类国产| 蜜桃一区二区三区在线| 国产在线视频不卡二| 成人午夜在线免费| 欧美做爰猛烈大尺度电影无法无天| 欧美日韩你懂得| 日韩精品一区国产麻豆| 中文字幕高清不卡| 一区二区三区四区在线播放 | 91国产免费看| 欧美一卡二卡三卡| 国产午夜精品久久久久久久 | 日本一二三不卡| 国产精品久久精品日日| 亚洲一区中文在线| 精品中文字幕一区二区小辣椒| 国产精品一卡二卡在线观看| 懂色av一区二区夜夜嗨| 欧美日韩一区精品| 久久久精品国产免费观看同学| 亚洲视频1区2区| 日本中文字幕一区| 国产98色在线|日韩| 在线观看网站黄不卡| 日韩欧美亚洲一区二区| 国产精品免费免费| 日日欢夜夜爽一区| 成人动漫精品一区二区| 4438亚洲最大| 国产精品久久久久aaaa樱花| 日韩中文字幕麻豆| 成人h动漫精品一区二区| 在线不卡免费欧美| 中文字幕色av一区二区三区| 午夜精品国产更新| 成人av电影在线| 日韩午夜精品电影| 亚洲精品乱码久久久久久黑人 | 亚洲va欧美va人人爽午夜| 国产精品正在播放| 欧美电影一区二区| 最新国产の精品合集bt伙计| 精品一区二区三区香蕉蜜桃| 欧美视频中文一区二区三区在线观看| 久久久av毛片精品| 日韩精品一级二级| 91美女片黄在线观看| 精品成人a区在线观看| 午夜婷婷国产麻豆精品| av一区二区三区在线| 精品1区2区在线观看| 亚洲午夜久久久久| 91伊人久久大香线蕉| 久久久精品tv| 狠狠色丁香婷综合久久| 6080亚洲精品一区二区| 一区二区三区四区在线免费观看 | 国产成a人无v码亚洲福利| 欧美经典三级视频一区二区三区| 亚洲国产欧美日韩另类综合 | 丁香婷婷综合五月| 久久亚洲一级片| 麻豆精品一区二区三区| 欧美三级电影在线观看| 玉足女爽爽91| 91蜜桃婷婷狠狠久久综合9色| 国产三级一区二区三区| 国产乱码精品一区二区三区忘忧草| 欧美一区二区三区日韩视频| 亚洲国产日韩一区二区| 在线观看不卡一区| 亚洲天堂福利av| 97成人超碰视| **性色生活片久久毛片| 成人午夜在线播放| 欧美激情在线一区二区三区| 国产成人精品免费一区二区| www成人在线观看| 激情丁香综合五月| 精品精品国产高清a毛片牛牛| 蜜桃一区二区三区四区| 日韩一区二区三区在线| 奇米色一区二区三区四区| 538在线一区二区精品国产| 日韩成人免费电影| 在线播放视频一区| 蜜桃精品在线观看| 精品久久久久久综合日本欧美 | 成人精品高清在线| 国产精品无码永久免费888| 成人久久久精品乱码一区二区三区| 国产欧美日本一区视频| 成人精品视频一区二区三区 | 久久蜜桃香蕉精品一区二区三区| 国产中文字幕一区| 中文字幕第一页久久| 99久久久久久| 亚洲国产成人av网| 日韩精品一区二区三区中文精品| 久久99国产乱子伦精品免费| 久久天堂av综合合色蜜桃网| 国产精品白丝av| 亚洲色图在线视频| 欧美午夜在线一二页| 裸体一区二区三区| 日本一区二区三区四区| 日本韩国精品在线| 美腿丝袜亚洲色图| 国产日产欧美一区二区三区| 91欧美一区二区| 日本欧美加勒比视频| 欧美mv和日韩mv的网站| 成人综合在线视频| 亚洲国产综合视频在线观看| 日韩三级中文字幕| www.亚洲色图| 婷婷开心久久网| 国产欧美精品一区二区三区四区| 99精品久久免费看蜜臀剧情介绍| 亚洲宅男天堂在线观看无病毒| 欧美一区二区三区啪啪| 成人高清视频在线观看| 天天影视色香欲综合网老头| 久久久久久久综合| 在线观看av一区| 久久99热狠狠色一区二区| 国产精品激情偷乱一区二区∴| 欧美日免费三级在线| 国产精品一区免费在线观看| 亚洲影院免费观看| 久久久久久久久久久99999| 欧洲国内综合视频| 国产精品综合视频| 亚洲高清免费视频| 中文字幕第一页久久| 日韩一区二区在线观看视频| av亚洲产国偷v产偷v自拍| 日本不卡免费在线视频| 成人免费小视频| 26uuu精品一区二区| 欧美日韩一二区| 丁香激情综合国产| 麻豆视频一区二区| 亚洲福利一区二区三区|