#include <iostream> using namespace std; //采用迭代器和空间配置器所实现的双向链表的基本功能 template<class _Ty,class _A = allocator<_Ty> > //定义模板类 class list //list类 { public: typedef size_t size_type; //类型重定义 protected: struct _Node; //结构体_Node friend struct _Node; //友元 typedef _Node* _Nodeptr; //类型重定义 struct _Node //结构体定义 { _Nodeptr _Next,_Prev; _Ty _Value; }; protected: _A allocator; _Nodeptr _Head; size_type _Size; public: typedef list<_Ty,_A> _Myt; typedef _A allocator_type; //该类型是模板参数A的同义词 typedef size_t size_type; //正整数类型 typedef ptrdiff_t difference_type; //整数类型 typedef _Ty* pointer; //指向_Ty的指针 typedef const _Ty* const_pointer; //指向_Ty的常量指针 typedef _Ty& reference; //_Ty的引用 typedef const _Ty& const_reference; //_Ty的常量引用 typedef _Ty value_type; //对象类型_Ty class iterator; //访问list的迭代器 class const_iterator; //访问list的常量迭代器 friend class const_iterator; //友元 class const_iterator : public _Bidit<_Ty, difference_type> //继承 { public: //共有成员 _Nodeptr _Mynode() const //指向当前结点 { return (_Ptr); } const_iterator() //默认构造函数 {} const_iterator(_Nodeptr _P):_Ptr(_P) //参数为指针的构造函数 {} const_iterator(const iterator& _X):_Ptr(_X._Ptr) //参数为访问list的常量迭代器的构造函数 {} const_reference operator*() const //获取当前_Ty的常量的值 { return _Ptr->_Value; } const_pointer operator->() const //? { return (&**this); } const_iterator& operator++() //前置++的引用 { _Ptr = _Ptr->_Next; return (*this); } const_iterator operator++(int) //后置++的引用 { const_iterator _Tmp = *this; ++*this; return (_Tmp); } const_iterator& operator--() //前置--的引用 { _Ptr = _Ptr->_Prev; return (*this); } const_iterator operator--(int) //后置--的引用 { const_iterator _Tmp = *this; --*this; return (_Tmp); } bool operator==(const const_iterator& _X) const //判断是否相等 { return (_Ptr == _X._Ptr); } bool operator!=(const const_iterator& _X) const //判断是否不等 { return (!(*this == _X)); } protected: //保护成员 _Nodeptr _Ptr; }; friend class iterator; //友元 class iterator : public const_iterator //继承 { public: iterator() //默认构造函数 {} iterator(_Nodeptr _P): const_iterator(_P) //参数为指针的构造函数 {} reference operator*() const //获取当前_Ty的值 { return _Ptr->_Value; } _Ty* operator->() const //? { return (&**this); } iterator& operator++() //前置++的引用 { _Ptr = _Ptr->_Next; return (*this); } iterator operator++(int) //后置++的引用 { iterator _Tmp = *this; ++*this; return (_Tmp); } iterator& operator--() //前置--的引用 { _Ptr = _Ptr->_Prev; return (*this); } iterator operator--(int) //后置--的引用 { iterator _Tmp = *this; --*this; return (_Tmp); } bool operator==(const iterator& _X) const //判断是否相等 { return (_Ptr == _X._Ptr); } bool operator!=(const iterator& _X) const //判断是否不等 { return (!(*this == _X)); } }; public: _Nodeptr _Buynode(_Nodeptr _Narg = 0, _Nodeptr _Parg = 0) //购买结点 { _Nodeptr _S = (_Nodeptr)allocator._Charalloc( //开辟空间 1 * sizeof (_Node)); _S->_Next = _Narg != 0 ? _Narg : _S;; _S->_Prev = _Parg != 0 ? _Parg : _S; return (_S); } void _Freenode(_Nodeptr _S) //释放空间 { allocator.deallocate(_S, 1); } void _Splice(iterator _P, _Myt& _X, iterator _F, iterator _L) //拼接 { if (allocator == _X.allocator) //将两个拼接到一起,_X清空 { (_L._Mynode())->_Prev->_Next = _P._Mynode(); (_F._Mynode())->_Prev->_Next = _L._Mynode(); (_P._Mynode())->_Prev->_Next = _F._Mynode(); _Nodeptr _S = (_P._Mynode())->_Prev; (_P._Mynode())->_Prev =(_L._Mynode())->_Prev; (_L._Mynode())->_Prev =(_F._Mynode())->_Prev; (_F._Mynode())->_Prev = _S; } else //将_X中的链表数值添加到_P中,_X清空 { insert(_P, _F, _L); _X.erase(_F, _L); } } void _Xran() const //抛出异常 { _THROW(out_of_range, "invalid list<T> subscript"); } public: size_type size() const //长度 { return (_Size); } bool empty() const //判空 { return (size() == 0); } _A get_allocator() const //返回空间配置器 { return (allocator); } void resize(size_type _N, _Ty _X = _Ty()) //重新定义链表长度 { if (size() < _N) { insert(end(), _N - size(), _X); } else { while (_N < size()) { pop_back(); } } } size_type max_size() const //返回链表最大可能长度 { return (allocator.max_size()); } reference front() //返回第一个元素的引用 { return (*begin()); } const_reference front() const //返回第一个元素的常量引用 { return (*begin()); } reference back() //返回最后一元素的引用 { return (*(--end())); } const_reference back() const //返回最后一元素的常量引用 { return (*(--end())); } _Myt& operator=(const _Myt& _X) //运算符构造函数 { if (this != &_X) { iterator _F1 = begin(); iterator _L1 = end(); const_iterator _F2 = _X.begin(); const_iterator _L2 = _X.end(); for (; _F1 != _L1 && _F2 != _L2; ++_F1, ++_F2) { *_F1 = *_F2; } erase(_F1, _L1); insert(_L1, _F2, _L2); } return (*this); } public: explicit list():_Head(_Buynode()), _Size(0) //空链表 {} explicit list(const _Ty& _V):_Head(_Buynode()), _Size(0) //建一个含_V个默认值是0的元素的链表 { insert(begin(),_V,0); } explicit list(size_type _N, const _Ty& _V):_Head(_Buynode()), _Size(0) //建一个含_V个元素的链表,值都是_N { insert(begin(),_N, _V); } list(const _Myt& _X): _Head(_Buynode()), _Size(0) //建一个_X的copy链表 { insert(begin(), _X.begin(), _X.end()); } list(const _Ty *_F, const _Ty *_L): _Head(_Buynode()), _Size(0) //一个区域的元素[_First, _Last)。 { insert(begin(), _F, _L); } typedef const_iterator _It; list(_It _F, _It _L):_Head(_Buynode()), _Size(0) //常量迭代器 { insert(begin(), _F, _L); } iterator begin() //迭代器第一个节点 { return iterator(_Head->_Next); } const_iterator begin() const //常量迭代器第一个节点 { return (const_iterator(_Head->_Next)); } iterator end() //返回最后一个元素的下一位置的指针 { return iterator(_Head); } const_iterator end() const //返回最后一个元素的下一位置的指针 { return (const_iterator(_Head)); } iterator insert(iterator _P,const _Ty& _X) //在_P之前插入结点 { _Nodeptr _S = _P._Mynode(); _S->_Prev = _Buynode(_S,_S->_Prev); _S = _S->_Prev; _S->_Prev->_Next = _S; _S->_Value = _X; ++_Size; return (iterator(_S)); } void insert(iterator _P,size_type _M, const _Ty& _X) //在_P之前插入_M个_X结点 { for(;0 < _M;--_M) { insert(_P,_X); } } void insert(iterator _P, const _Ty *_F, const _Ty *_L) //在_P之前插入_F到_L的结点 { for (; _F != _L; ++_F) { insert(_P, *_F); } } typedef const_iterator _It; void insert(iterator _P, _It _F, _It _L) //在_P之前插入迭代器_F到_L的结点 { for (; _F != _L; ++_F) { insert(_P, *_F); } } void push_front(const _Ty& _X) //增加一元素到链表头 { insert(begin(), _X); } void pop_front() //删除链表头的一元素 { erase(begin()); } void push_back(const _Ty& _X) //增加一元素到链表尾 { insert(end(), _X); } void pop_back() //删除链表尾的一个元素 { erase(--end()); } void assign(size_type _N, const _Ty& _X) //分配值 { erase(begin(),end()); insert(begin(),_N, _X); } iterator erase(iterator _P) //删除_P元素 { _Nodeptr _S = (_P++)._Mynode(); _S->_Prev->_Next = _S->_Next; _S->_Next->_Prev = _S->_Prev; _Freenode(_S); --_Size; return (_P); } iterator erase(iterator _F, iterator _L) //删除_F到_L区域的元素 { while (_F != _L) { erase(_F++); } return (_F); } void clear() //删除所有元素 { erase(begin(),end()); } void show() //STL源码中不存在的函数,自己加的,为了使得测试更方便 { _Nodeptr _P = _Head->_Next; while(_P != _Head) { cout<<_P->_Value<<"-->"; _P = _P->_Next; } cout<<"Over"<<endl; } ~list() //析构函数 { erase(begin(),end()); _Freenode(_Head); _Head = 0, _Size = 0; } public: void swap(_Myt& _X) //交换两个链表 { if (allocator == _X.allocator) //若空间配置器相同,则只需交换头结点和大小 { std::swap(_Head, _X._Head); std::swap(_Size, _X._Size); } else //否则将链表分别拼接到对方空间中 { iterator _P = begin(); splice(_P, _X); _X.splice(_X.begin(), *this, _P, end()); } } friend void swap(_Myt& _X, _Myt& _Y) //交换两个链表 { _X.swap(_Y); } void splice(iterator _P, _Myt& _X) //对两个链表进行拼接 { if (!_X.empty()) { _Splice(_P, _X, _X.begin(), _X.end()); _Size += _X._Size; _X._Size = 0; } } void splice(iterator _P, _Myt& _X, iterator _F) //对两个链表进行拼接 { iterator _L = _F; if (_P != _F && _P != ++_L) { _Splice(_P, _X, _F, _L); ++_Size; --_X._Size; } } void splice(iterator _P, _Myt& _X, iterator _F, iterator _L) //对两个链表进行拼接 { if (_F != _L) { if (&_X != this) { difference_type _N = 0; _Distance(_F, _L, _N); _Size += _N; _X._Size -= _N; } _Splice(_P, _X, _F, _L); } } void remove(const _Ty& _V) //从链表中删除所有值为_V的元素 { iterator _L = end(); for (iterator _F = begin(); _F != _L; ) { if (*_F == _V) { erase(_F++); } else { ++_F; } } } void unique() //删除所有重复的元素,以建立一个具有唯一元素值的链表, //即链表中不会有重复元素 { iterator _F = begin(), _L = end(); if (_F != _L) { for (iterator _M = _F; ++_M != _L; _M = _F) { if (*_F == *_M) { erase(_M); } else { _F = _M; } } } } void merge(_Myt& _X) //把当前链表*this和x合并,合并后x为空, //把x中的元素插入到当前链表中,不允许两个链表相同 { if (&_X != this) { iterator _F1 = begin(), _L1 = end(); iterator _F2 = _X.begin(), _L2 = _X.end(); while (_F1 != _L1 && _F2 != _L2) { if (*_F2 < *_F1) { iterator _Mid2 = _F2; _Splice(_F1, _X, _F2, ++_Mid2); _F2 = _Mid2; } else { ++_F1; } } if (_F2 != _L2) { _Splice(_L1, _X, _F2, _L2); } _Size += _X._Size; _X._Size = 0; } } void reverse() //反转链表中的元素排序 { if (2 <= size()) { iterator _L = end(); for (iterator _F = ++begin(); _F != _L; ) { iterator _M = _F; _Splice(begin(), *this, _M, ++_F); } } } void sort() //根据默认条件对链表进行排序? { if (2 <= size()) { const size_t _MAXN = 15; _Myt _X, _A[_MAXN + 1]; size_t _N = 0; while (!empty()) { _X.splice(_X.begin(), *this, begin()); size_t _I; for (_I = 0; _I < _N && !_A[_I].empty(); ++_I) { _A[_I].merge(_X); _A[_I].swap(_X); } if (_I == _MAXN) { _A[_I].merge(_X); } else { _A[_I].swap(_X); if (_I == _N) { ++_N; } } } while (0 < _N) { merge(_A[--_N]); } } } }; template<class _Ty, class _A> inline //模板类判断是否相等 bool operator==(const list<_Ty, _A>& _X, const list<_Ty, _A>& _Y) { return (_X.size() == _Y.size() && equal(_X.begin(), _X.end(), _Y.begin())); } template<class _Ty, class _A> inline //模板类判断是否不等 bool operator!=(const list<_Ty, _A>& _X, const list<_Ty, _A>& _Y) { return (!(_X == _Y)); } template<class _Ty, class _A> inline //模板类比较链表的大小 bool operator<(const list<_Ty, _A>& _X, const list<_Ty, _A>& _Y) { return (lexicographical_compare(_X.begin(), _X.end(), _Y.begin(), _Y.end())); } template<class _Ty, class _A> inline //模板类比较链表的大小_Y < _X bool operator>(const list<_Ty, _A>& _X, const list<_Ty, _A>& _Y) { return (_Y < _X); } template<class _Ty, class _A> inline //模板类比较链表的大小!(_Y < _X) bool operator<=(const list<_Ty, _A>& _X, const list<_Ty, _A>& _Y) { return (!(_Y < _X)); } template<class _Ty, class _A> inline //模板类比较链表的大小!(_X < _Y) bool operator>=(const list<_Ty, _A>& _X, const list<_Ty, _A>& _Y) { return (!(_X < _Y)); } void main() { list<int> c0; //空链表 list<int> c1(3); //建一个含三个默认值是0的元素的链表 list<int> c2(c1); //建一个c1的copy链表 list<int> c3(c1.begin(),c1.end()); //含c1一个区域的元素[_First, _Last)。 int ar[5] = {2,3,4,5,6}; list<int> itlist(ar,ar+5); //用数组赋值 list<int> mylist(3,2); //建一个含三个元素的链表,值都是2 mylist.show(); list<int> youlist(3,3); youlist.show(); swap(mylist, youlist); //交换两个链表 mylist.show(); youlist.show(); mylist.swap(youlist); mylist.show(); youlist.show(); list<int>::iterator i1 = itlist.begin(); itlist.splice(i1,mylist); //对两个链表进行结合 itlist.show(); itlist.remove(3); itlist.show(); itlist.unique(); itlist.show(); itlist.merge(mylist); itlist.show(); mylist.show(); itlist.reverse(); itlist.show(); itlist.sort(); itlist.show(); cout<<operator<(itlist,mylist)<<endl; cout<<operator>(itlist,mylist)<<endl; }
版权声明:本文为博主原创文章,未经博主允许不得转载。
原文地址:http://blog.csdn.net/weichanjuan3/article/details/47058853