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

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

?? deque

?? C標準庫源代碼,能提高對C的理解,不錯的哦
??
?? 第 1 頁 / 共 2 頁
字號:
// deque standard header

#if     _MSC_VER > 1000 /*IFSTRIP=IGN*/
#pragma once
#endif

#ifndef _DEQUE_
#define _DEQUE_
#include <iterator>
#include <memory>
#include <stdexcept>
#include <xutility>

#ifdef  _MSC_VER
#pragma pack(push,8)
#endif  /* _MSC_VER */
_STD_BEGIN
#define _DEQUEMAPSIZ	2
#define _DEQUESIZ (4096 < sizeof (_Ty) ? 1 : 4096 / sizeof (_Ty))
		// TEMPLATE CLASS deque
template<class _Ty, class _A = allocator<_Ty> >
	class deque {
public:
	typedef deque<_Ty, _A> _Myt;
	typedef _A allocator_type;
	typedef _A::size_type size_type;
	typedef _A::difference_type difference_type;
	typedef _A::pointer _Tptr;
	typedef _A::const_pointer _Ctptr;
	typedef _POINTER_X(_Tptr, _A) _Mapptr;
	typedef _A::reference reference;
	typedef _A::const_reference const_reference;
	typedef _A::value_type value_type;
		// CLASS const_iterator
	class iterator;
	class const_iterator : public _Ranit<_Ty, difference_type> {
	public:
		friend class deque<_Ty, _A>;
		const_iterator()
			: _First(0), _Last(0), _Next(0), _Map(0) {}
		const_iterator(_Tptr _P, _Mapptr _M)
			: _First(*_M), _Last(*_M + _DEQUESIZ),
				_Next(_P), _Map(_M) {}
		const_iterator(const iterator& _X)
			: _First(_X._First), _Last(_X._Last), _Next(_X._Next), 
			  _Map(_X._Map) {}
		const_reference operator*() const
			{return (*_Next); }
		_Ctptr operator->() const
			{return (&**this); }
		const_iterator& operator++()
			{if (++_Next == _Last)
				{_First = *++_Map;
				_Last = _First + _DEQUESIZ;
				_Next = _First; }
			return (*this); }
		const_iterator operator++(int)
			{const_iterator _Tmp = *this;
			++*this;
			return (_Tmp); }
		const_iterator& operator--()
			{if (_Next == _First)
				{_First = *--_Map;
				_Last = _First + _DEQUESIZ;
				_Next = _Last; }
			--_Next;
			return (*this); }
		const_iterator operator--(int)
			{const_iterator _Tmp = *this;
			--*this;
			return (_Tmp); }
		const_iterator& operator+=(difference_type _N)
			{_Add(_N);
			return (*this); }
		const_iterator& operator-=(difference_type _N)
			{return (*this += -_N); }
		const_iterator operator+(difference_type _N) const
			{const_iterator _Tmp = *this;
			return (_Tmp += _N); }
		const_iterator operator-(difference_type _N) const
			{const_iterator _Tmp = *this;
			return (_Tmp -= _N); }
		difference_type operator-(const const_iterator& _X) const
			{return (_Map == _X._Map ? _Next - _X._Next
				: _DEQUESIZ * (_Map - _X._Map - 1)
				+ (_Next - _First) + (_X._Last - _X._Next)); }
		const_reference operator[](difference_type _N) const
			{return (*(*this + _N)); }
		bool operator==(const const_iterator& _X) const
			{return (_Next == _X._Next); }
		bool operator!=(const const_iterator& _X) const
			{return (!(*this == _X)); }
		bool operator<(const const_iterator& _X) const
			{return (_Map < _X._Map
				|| _Map == _X._Map && _Next < _X._Next); }
		bool operator<=(const const_iterator& _X) const
			{return (!(_X < *this)); }
		bool operator>(const const_iterator& _X) const
			{return (_X < *this); }
		bool operator>=(const const_iterator& _X) const
			{return (!(*this < _X)); }
	protected:
		void _Add(difference_type _N)
			{difference_type _Off = _N + _Next - _First;
			difference_type _Moff = (0 <= _Off)
				? _Off / _DEQUESIZ
				: -((_DEQUESIZ - 1 - _Off) / _DEQUESIZ);
			if (_Moff == 0)
				_Next += _N;
			else
				{_Map += _Moff;
				_First = *_Map;
				_Last = _First + _DEQUESIZ;
				_Next = _First + (_Off - _Moff * _DEQUESIZ); }}
	_PROTECTED:
		_Tptr _First, _Last, _Next;
		_Mapptr _Map;
		};
		// CLASS iterator
	class iterator : public const_iterator {
	public:
		iterator()
			{}
		iterator(_Tptr _P, _Mapptr _M)
			: const_iterator(_P, _M) {}
		reference operator*() const
			{return (*_Next); }
		_Tptr operator->() const
			{return (&**this); }
		iterator& operator++()
			{if (++_Next == _Last)
				{_First = *++_Map;
				_Last = _First + _DEQUESIZ;
				_Next = _First; }
			return (*this); }
		iterator operator++(int)
			{iterator _Tmp = *this;
			++*this;
			return (_Tmp); }
		iterator& operator--()
			{if (_Next == _First)
				{_First = *--_Map;
				_Last = _First + _DEQUESIZ;
				_Next = _Last; }
			--_Next;
			return (*this); }
		iterator operator--(int)
			{iterator _Tmp = *this;
			--*this;
			return (_Tmp); }
		iterator& operator+=(difference_type _N)
			{_Add(_N);
			return (*this); }
		iterator& operator-=(difference_type _N)
			{return (*this += -_N); }
		iterator operator+(difference_type _N) const
			{iterator _Tmp = *this;
			return (_Tmp += _N); }
		iterator operator-(difference_type _N) const
			{iterator _Tmp = *this;
			return (_Tmp -= _N); }
		difference_type operator-(const iterator& _X) const
			{return (_Map == _X._Map ? _Next - _X._Next
				: _DEQUESIZ * (_Map - _X._Map - 1)
				+ (_Next - _First) + (_X._Last - _X._Next)); }
		reference operator[](difference_type _N) const
			{return (*(*this + _N)); }
		bool operator==(const iterator& _X) const
			{return (_Next == _X._Next); }
		bool operator!=(const iterator& _X) const
			{return (!(*this == _X)); }
		bool operator<(const iterator& _X) const
			{return (_Map < _X._Map
				|| _Map == _X._Map && _Next < _X._Next); }
		bool operator<=(const iterator& _X) const
			{return (!(_X < *this)); }
		bool operator>(const iterator& _X) const
			{return (_X < *this); }
		bool operator>=(const iterator& _X) const
			{return (!(*this < _X)); }
		};
	typedef reverse_iterator<const_iterator, value_type,
		const_reference, _Ctptr, difference_type>
			const_reverse_iterator;
	typedef reverse_iterator<iterator, value_type,
		reference, _Tptr, difference_type>
			reverse_iterator;
	explicit deque(const _A& _Al = _A())
		: allocator(_Al),
			_First(), _Last(), _Map(0), _Mapsize(0), _Size(0)
		{}
	explicit deque(size_type _N, const _Ty& _V = _Ty(),
		const _A& _Al = _A())
		: allocator(_Al),
			_First(), _Last(), _Map(0), _Mapsize(0), _Size(0)
		{insert(begin(), _N, _V); }
	deque(const _Myt& _X)
		: allocator(_X.allocator),
			_First(), _Last(), _Map(0), _Mapsize(0), _Size(0)
		{copy(_X.begin(), _X.end(), back_inserter(*this)); }
	typedef const_iterator _It;
		deque(_It _F, _It _L, const _A& _Al = _A())
		: allocator(_Al),
			_First(), _Last(), _Map(0), _Mapsize(0), _Size(0)
		{copy(_F, _L, back_inserter(*this)); }
	~deque()
		{while (!empty())
			pop_front(); }
	_Myt& operator=(const _Myt& _X)
		{if (this != &_X)
			{iterator _S;
			if (_X.size() <= size())
				{_S = copy(_X.begin(), _X.end(), begin());
				erase(_S, end()); }
			else
				{const_iterator _Sx = _X.begin() + size();
				_S = copy(_X.begin(), _Sx, begin());
				copy(_Sx, _X.end(), inserter(*this, _S)); }}
		return (*this); }
	iterator begin()
		{return (_First); }
	const_iterator begin() const
		{return ((const_iterator)_First); }
	iterator end()
		{return (_Last); }
	const_iterator end() const
		{return ((const_iterator)_Last); }
	reverse_iterator rbegin()
		{return (reverse_iterator(end())); }
	const_reverse_iterator rbegin() const
		{return (const_reverse_iterator(end())); }
	reverse_iterator rend()
		{return (reverse_iterator(begin())); }
	const_reverse_iterator rend() const
		{return (const_reverse_iterator(begin())); }
	void resize(size_type _N, _Ty _X = _Ty())
		{if (size() < _N)
			insert(end(), _N - size(), _X);
		else if (_N < size())
			erase(begin() + _N, end()); }
	size_type size() const
		{return (_Size); }
	size_type max_size() const
		{return (allocator.max_size()); }
	bool empty() const
		{return (size() == 0); }
	_A get_allocator() const
		{return (allocator); }
	const_reference at(size_type _P) const
		{if (size() <= _P)
			_Xran();
		return (*(begin() + _P)); }
	reference at(size_type _P)
		{if (size() <= _P)
			_Xran();
		return (*(begin() + _P)); }
	const_reference operator[](size_type _P) const
		{return (*(begin() + _P)); }
	reference operator[](size_type _P)
		{return (*(begin() + _P)); }
	reference front()
		{return (*begin()); }
	const_reference front() const
		{return (*begin()); }
	reference back()
		{return (*(end() - 1)); }
	const_reference back() const
		{return (*(end() - 1)); }
	void push_front(const _Ty& _X)
		{if (empty() || _First._Next == _First._First)
			_Buyfront();
		allocator.construct(--_First._Next, _X);
		++_Size; }
	void pop_front()
		{allocator.destroy(_First._Next++);
		--_Size;
		if (empty() || _First._Next == _First._Last)
			_Freefront(); }
	void push_back(const _Ty& _X)
		{
		if (empty() || (_Last._Next == _Last._Last))
        {
            _Buyback();
            allocator.construct(_Last._Next++, _X);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区在线视频播放| 国产亚洲一区二区三区在线观看| 极品少妇xxxx精品少妇偷拍| 亚洲成人精品一区| 亚洲一本大道在线| 调教+趴+乳夹+国产+精品| 亚洲欧美成aⅴ人在线观看| 国产精品丝袜91| 亚洲色大成网站www久久九九| 国产日韩欧美a| 中文字幕第一区二区| 亚洲天堂免费看| 一区二区三区视频在线观看| 一区二区免费在线播放| 亚洲另类在线制服丝袜| 亚洲电影中文字幕在线观看| 偷窥少妇高潮呻吟av久久免费| 日韩电影免费一区| 国产乱码精品一区二区三区忘忧草| 国产在线播放一区二区三区 | 成人高清免费观看| 成人av在线播放网址| 色婷婷亚洲综合| 欧美高清一级片在线| 精品日韩在线观看| 成人欧美一区二区三区在线播放| 亚洲乱码国产乱码精品精98午夜| 五月激情综合色| 国产精品18久久久久久久久 | 色婷婷综合在线| 在线观看日韩av先锋影音电影院| 欧美人与性动xxxx| 国产亚洲欧美在线| 亚洲一二三区在线观看| 国产精品一区免费视频| 欧美丝袜自拍制服另类| 久久一留热品黄| 亚洲黄色在线视频| 国产一区二区三区免费播放| 91丨九色丨黑人外教| 欧美一级电影网站| 日韩美女视频一区二区| 久久国产精品色婷婷| 在线国产电影不卡| 久久久不卡网国产精品二区| 香蕉久久夜色精品国产使用方法| 国产福利91精品一区二区三区| 欧美主播一区二区三区美女| 久久久久久一二三区| 亚洲一区视频在线| 99热精品国产| 久久一区二区三区国产精品| 午夜精品一区在线观看| 99视频超级精品| 国产欧美一区二区三区在线看蜜臀| 五月天中文字幕一区二区| av男人天堂一区| 国产午夜精品久久久久久免费视| 午夜久久久影院| 色婷婷综合久久久久中文| 欧美激情在线观看视频免费| 精品制服美女丁香| 日韩一区二区在线播放| 亚洲一区在线看| 91免费在线视频观看| 中文在线资源观看网站视频免费不卡| 免费久久99精品国产| 制服丝袜中文字幕亚洲| 亚洲一本大道在线| 欧美日韩国产123区| 一区二区三区四区视频精品免费 | 国产精品成人一区二区三区夜夜夜 | 国产东北露脸精品视频| 精品噜噜噜噜久久久久久久久试看| 蜜桃一区二区三区在线| 欧美性淫爽ww久久久久无| 亚洲欧美国产毛片在线| 91麻豆精品在线观看| 亚洲欧美偷拍另类a∨色屁股| av电影在线观看完整版一区二区| 国产日韩亚洲欧美综合| 国产成人自拍高清视频在线免费播放| 日韩女优视频免费观看| 九色综合国产一区二区三区| 久久人人超碰精品| 国产成人激情av| 国产精品乱码一区二三区小蝌蚪| 成人美女视频在线观看18| 国产精品免费人成网站| 色香蕉成人二区免费| 亚洲国产视频网站| 制服丝袜亚洲色图| 国产一区二区电影| 亚洲同性同志一二三专区| 在线欧美日韩精品| 美女视频网站黄色亚洲| 久久久久久久综合日本| 91色porny在线视频| 五月婷婷激情综合网| 精品欧美一区二区三区精品久久 | 国产精品日日摸夜夜摸av| 色国产精品一区在线观看| 亚洲一区二区三区国产| 精品国产凹凸成av人导航| 成人性色生活片免费看爆迷你毛片| 亚洲视频资源在线| 欧美一区二区三区在线电影| 精品亚洲国产成人av制服丝袜| 欧美国产一区视频在线观看| 91麻豆国产精品久久| 美女在线一区二区| 亚洲欧美日韩中文字幕一区二区三区 | 首页亚洲欧美制服丝腿| 国产偷v国产偷v亚洲高清| 色菇凉天天综合网| 国产一区在线不卡| 亚洲国产日韩综合久久精品| 精品动漫一区二区三区在线观看| 99久久er热在这里只有精品66| 日韩精品免费专区| 亚洲欧洲韩国日本视频| 精品免费视频一区二区| 91福利在线播放| 国产成人无遮挡在线视频| 天堂久久一区二区三区| 国产精品日韩成人| 久久这里只有精品视频网| 色哦色哦哦色天天综合| 国产很黄免费观看久久| 三级成人在线视频| 一卡二卡三卡日韩欧美| 日本一区免费视频| 日韩欧美国产一区二区三区| 色婷婷亚洲婷婷| 丁香婷婷综合色啪| 美女性感视频久久| 亚洲电影一区二区| 亚洲柠檬福利资源导航| 亚洲欧洲精品成人久久奇米网| 精品国产乱码久久久久久影片| 884aa四虎影成人精品一区| 99精品久久只有精品| 成人午夜精品在线| 国产超碰在线一区| 国产乱人伦偷精品视频免下载| 免费高清在线一区| 日韩av中文字幕一区二区 | 久久一区二区三区四区| 日韩一区二区不卡| 精品久久国产字幕高潮| 制服丝袜一区二区三区| 在线电影国产精品| 精品视频在线免费看| 日本乱人伦aⅴ精品| 欧美视频在线观看一区二区| 在线观看网站黄不卡| 欧美日韩视频在线第一区| 欧美日韩一区二区三区高清| 欧美三级日本三级少妇99| 欧美影片第一页| 欧美伦理视频网站| 精品久久国产字幕高潮| 久久久一区二区| 欧美国产视频在线| 综合欧美亚洲日本| 夜夜操天天操亚洲| 石原莉奈在线亚洲三区| 美女视频黄 久久| 国产精品中文有码| 成人不卡免费av| 在线这里只有精品| 在线不卡一区二区| 久久综合999| 国产精品成人免费| 亚洲成人av一区二区| 久久99国产精品久久| 成人18精品视频| 欧美日韩亚洲综合在线| 欧美电影免费观看高清完整版在线观看 | 久久久国产午夜精品 | 亚洲一区二区三区在线| 日韩激情视频在线观看| 国产原创一区二区| 91影院在线观看| 日韩一区二区精品在线观看| 国产欧美中文在线| 午夜激情久久久| 成人一级视频在线观看| 欧美日韩aaaaaa| 国产人成一区二区三区影院| 亚洲综合激情小说| 国产一区二区毛片| 91成人免费在线视频| 久久综合成人精品亚洲另类欧美| 亚洲色图另类专区| 国产精品一二三在| 欧美军同video69gay| 中文字幕一区二区三区蜜月| 日本中文字幕不卡| 欧美综合欧美视频|