JJ

#ifndef UTIL_CHAINLIB_H
#define UTIL_CHAINLIB_H

#include <assert.h>
#include <new>
#include <iostream>
#include <algorithm>
#include <vector>

namespace util {

	/**
	* 这是一个排序的链表，分配的内存将不会删除，直到对象销毁时才删
	*
	* @notice 对象T需要支持 <, =, << 3个操作符
	*/

	template<typename T>
	struct NodeObject {
		T obj; // 对象存放

		NodeObject* prev; // 前一个指针
		NodeObject* next; // 后一个指针

						  //////////////////////////////////////////////////////////////////////////
		NodeObject() : prev(NULL), next(NULL) {}
		NodeObject(const T& o) : prev(NULL), next(NULL) {
			memcpy(&obj, &o, sizeof(T));
		}
		NodeObject(const NodeObject<T>& t) {
			memcpy(&obj, &(t.obj), sizeof(T));
			prev = t.prev;
			next = t.next;
		}

		//
		NodeObject& operator = (const T& o) {
			memcpy(&obj, &o, sizeof(T));
			return *this;
		}
		NodeObject& operator = (const NodeObject<T>& t) {
			memcpy(&obj, &(t.obj), sizeof(T));
			prev = t.prev;
			next = t.next;
			return *this;
		}
		operator bool() const {
			return (NULL != prev || NULL != next);
		}
	};

	template<typename F, typename S>
	struct PairType {
		F   first;
		S   second;

		PairType() : first(), second() { }
		PairType(const PairType& r) {
			*this = r;
		}
		PairType(F f, S s) : first(f), second(s) {}
		PairType& operator = (const PairType& r) {
			first = r.first;//lint !e1555
			second = r.second;
			return *this;
		}
	};

	//
	template<typename T>
	class SortChain {
	public:
		typedef NodeObject<T>* NodePtr;

		//
		SortChain() : _pWorkChainHead(NULL), _pWorkChainTail(NULL), _pRecuChainTail(NULL),
			_pNextChainHead(NULL), _pNextCurObj(NULL), _workNum(0) {
		}
		~SortChain() {
			delAll();
		}

		// 增加方法，防止内存泄露
		SortChain<T>& operator= (const SortChain<T>& r) {
			if (&r == this) {
				return *this;
			}

			this->clear();
			SortChain<T>& iR = const_cast<SortChain<T>&>(r);
			iR.rewind();

			while (iR.next()) {
				this->push_back(iR.get());
			}

			iR.rewind();

			return *this;
		}
		SortChain(const SortChain<T>& r) : _pWorkChainHead(NULL), _pWorkChainTail(NULL), _pRecuChainTail(NULL),
			_pNextChainHead(NULL), _pNextCurObj(NULL), _workNum(0) {
			*this = r;
		}

		/**
		* 查找，二分查找
		*
		* @return, pair前面的T指针是个参考值，
		*          如果链表为NULL，<NULL, -2>
		*          如果找到了与obj相等的链表节点，<first, 0>，first是指向找到节点的指针
		*          如果没有找到，最后找到的节点比obj大，<first, -1>, obj后续应该插在first前
		*                                           小，<first, 1>， obj后续应该插在first后
		* @warnning 只适合于insert方式插入的链表
		*/
		typedef PairType<NodeObject<T>*, int> Find_type; //-2, 链表是空; -1, <; 0 ==, 1 >
		Find_type findObj(const T& obj) {
			if (0 == _workNum) {
				return Find_type(NULL, -2);
			}

			int nMid;
			int nHead = 1;
			int nTail = _workNum;
			NodeObject<T>* pHead = _pWorkChainHead;
			NodeObject<T>* pMid = NULL;

			//
			int nType = 0;

			while (nHead <= nTail) {
				pMid = pHead;
				nMid = (nHead + nTail) / 2;

				for (int i = nHead; (pMid != NULL) && (i < nMid); ++i) {
					pMid = pMid->next;
				}

				if (NULL == pMid) {
					break;
				}

				// 比较
				if (obj < pMid->obj) { // 小于
					nTail = nMid - 1;
					nType = -1;

				}
				else if (pMid->obj < obj) { // 大于
					pHead = pMid->next;
					nHead = nMid + 1;
					nType = 1;

				}
				else { // 找到
					nType = 0;
					break;
				}
			}

			return Find_type(pMid, nType);
		}

		/**
		* 查找，二分查找
		*
		* @return, 没有找到 NULL；找到了 返回obj在链表中数据存放的指针
		* @warnning 只适合于insert方式插入的链表
		*/
		T* find(const T& obj) {
			Find_type ft = findObj(obj);

			if (0 == ft.second) {
				return &(ft.first->obj);
			}

			return NULL;
		}

		/**
		* 排序插入
		*
		* @return, 如果obj在链表中已经存在 <first, false>, first是obj已经存在的数据对象指针
		*          如果不存在，<first, true>，first是obj在链表中的数据对象指针
		* @warning, obj有 <, = 操作符的实现
		*/
		typedef PairType<T*, bool> Insert_type;
		//lint -ecall(534,util::SortChain<*>::insert) 
		Insert_type insert(const T& obj) {
			// 判断是否为空链
			if (NULL == _pWorkChainHead) {
				_pWorkChainHead = alloc();
				_pWorkChainTail = _pWorkChainHead;
				_pWorkChainHead->obj = obj;
				++_workNum;
				return Insert_type(&(_pWorkChainHead->obj), true);
			}

			// 查找
			Find_type ft = findObj(obj);

			if (NULL == ft.first) {
				// throw
			}

			if (0 == ft.second) {
				return Insert_type(&(ft.first->obj), false);
			}

			// 分配空间存储
			++_workNum;
			NodeObject<T>* pTmp = alloc();
			pTmp->obj = obj;

			// 组织链
			NodeObject<T>* pPrev = ft.first->prev;
			NodeObject<T>* pNext = ft.first->next;

			if (ft.second < 0) {            // 小于，放在前面
				ft.first->prev = pTmp;
				pTmp->prev = pPrev;
				pTmp->next = ft.first;

				if (pPrev != NULL) {
					pPrev->next = pTmp;

				}
				else {
					_pWorkChainHead = pTmp; // 为空将成为首指针
				}

			}
			else if (ft.second > 0) {     // 大于，放在后面
				ft.first->next = pTmp;
				pTmp->prev = ft.first;
				pTmp->next = pNext;

				if (pNext != NULL) {
					pNext->prev = pTmp;

				}
				else {
					_pWorkChainTail = pTmp; // 为空是最后一个位置
				}
			}

			return Insert_type(&(pTmp->obj), true);
		}

		// 非排序前插入，也不判唯一性
		//lint -ecall(534,util::SortChain<*>::push_front) 
		NodeObject<T>* push_front(const T& obj) {
			NodeObject<T>* pTmp = alloc();
			pTmp->obj = obj;

			++_workNum;

			if (NULL == _pWorkChainHead) { // 第一次
				_pWorkChainHead = pTmp;
				_pWorkChainTail = pTmp;
				return pTmp;
			}

			pTmp->next = _pWorkChainHead;
			_pWorkChainHead->prev = pTmp;
			_pWorkChainHead = pTmp;

			return _pWorkChainHead;
		}

		// 非排序后插入，也不判唯一性
		//lint -ecall(534,util::SortChain<*>::push_back) 
		NodeObject<T>* push_back(const T& obj) {
			NodeObject<T>* pTmp = alloc();
			pTmp->obj = obj;

			++_workNum;

			if (NULL == _pWorkChainTail) { // 第一次
				_pWorkChainHead = pTmp;
				_pWorkChainTail = pTmp;
				return pTmp;
			}

			_pWorkChainTail->next = pTmp;
			pTmp->prev = _pWorkChainTail;
			_pWorkChainTail = pTmp;

			return _pWorkChainTail;
		}

		// 从前面弹出
		bool pop_front(T& pObj) {
			if (NULL == _pWorkChainHead) {
				return false;
			}

			// 赋值
			pObj = _pWorkChainHead->obj;

			// 删节点
			NodeObject<T>* pTmp = _pWorkChainHead;
			_pWorkChainHead = pTmp->next;

			if (_pWorkChainHead != NULL) {
				_pWorkChainHead->prev = NULL;

			}
			else {
				_pWorkChainTail = NULL; // 为空时，链尾也为空
			}

			recu(pTmp);
			--_workNum;

			return true;
		}

		// 从后面弹出
		bool pop_back(T& pObj) {
			if (NULL == _pWorkChainTail) {
				return false;
			}

			// 赋值
			NodeObject<T>* pTmp = _pWorkChainTail;
			pObj = pTmp->obj;

			// 删节点
			_pWorkChainTail = pTmp->prev;

			if (_pWorkChainTail != NULL) {
				_pWorkChainTail->next = NULL;

			}
			else {
				_pWorkChainHead = NULL;  // 为空时，链首也为空
			}

			recu(pTmp);
			--_workNum;

			return true;
		}

		/**
		* 删除
		*
		* 返回值：1，找到且删除；0，没有找到
		* @warnning, 通过insert方式的才能调这个函数
		*/
		//lint -ecall(534,util::SortChain<*>::remove) 
		int remove(const T& obj) {
			// 查找
			Find_type ft = findObj(obj);

			// 没有找到
			if (NULL == ft.first || ft.second != 0) {
				return 0;
			}

			// 删节点
			remove(ft.first);

			return 1;
		}
		void remove(NodeObject<T>* pT) {
			if (NULL == pT) {
				return;
			}

			// 拆链
			NodeObject<T>* pPrev = pT->prev;
			NodeObject<T>* pNext = pT->next;

			if (pPrev != NULL) {
				pPrev->next = pNext;

			}
			else { // 删除的是第一个节点，重置链首指针
				_pWorkChainHead = pNext;

				if (NULL != _pWorkChainHead) {
					_pWorkChainHead->prev = NULL;
				}
			}

			if (pNext != NULL) {
				pNext->prev = pPrev;

			}
			else { // 删除的是最后一个节点，尾链指向前一个
				_pWorkChainTail = pPrev;

				if (NULL != _pWorkChainTail) {
					_pWorkChainTail->next = NULL;
				}
			}

			// 回收
			recu(pT);
			--_workNum;
		}

		// 第一个指针链对象
		NodeObject<T>* first() {
			return _pWorkChainHead;
		}
		// 最后一个指针链对象
		NodeObject<T>* last() {
			return _pWorkChainTail;
		}
		// 正向复位遍历
		void rewind() {
			_pNextChainHead = _pWorkChainHead;
		}
		// 逆向复位遍历
		void reverseRewind() {
			_pNextChainHead = _pWorkChainTail;
		}

		/**
		* 遍历，配合get()方法使用
		*
		* @return  有数据 true，没有数据 false
		* @warning 之前必须先调用 rewind()方法
		*/
		bool next() {
			if (_pNextChainHead != NULL) {
				_pNextCurObj = _pNextChainHead;
				_pNextChainHead = _pNextChainHead->next;
				return true;
			}

			_pNextCurObj = NULL;
			return false;
		}
		// 逆向查找
		bool reverseNext() {
			if (_pNextChainHead != NULL) {
				_pNextCurObj = _pNextChainHead;
				_pNextChainHead = _pNextChainHead->prev;
				return true;
			}

			_pNextCurObj = NULL;
			return false;
		}

		// 取得next()后对应的T数据
		const T& get() const {
			assert(_pNextCurObj);
			return _pNextCurObj->obj;
		}

		// 把工作链上的所有节点，放入回收队列
		void clear() {
			_workNum = 0;

			if (NULL == _pWorkChainHead) {
				return;
			}

			NodeObject<T>* pTail = _pWorkChainTail;

			if (_pRecuChainTail != NULL) {
				_pRecuChainTail->next = _pWorkChainHead;
				_pWorkChainHead->prev = _pRecuChainTail;
			}

			_pWorkChainHead = NULL; // 链首赋空
			_pWorkChainTail = NULL; // 链尾赋空
			_pRecuChainTail = pTail;
		}

		// 输出内容，需要T支持 << 操作赋
		void show(int maxNum = 1024) {
			int curPos = 0;
			NodeObject<T>* pTmp = _pWorkChainHead;

			while (pTmp != NULL && curPos < maxNum) {
				std::cout << curPos++ << " : " << pTmp->obj << std::endl;
				pTmp = pTmp->next;
			}
		}

		T* operator[](size_t i) {
			if (i >= _workNum) {
				return NULL;
			}

			NodeObject<T>* pTmp = _pWorkChainHead;
			assert(pTmp);

			for (int j = 0; j < i; ++j) {
				pTmp = pTmp->next;
			}

			return &(pTmp->obj);
		}

		NodeObject<T>* at(size_t i) {
			if (i >= _workNum) {
				return NULL;
			}

			NodeObject<T>* pTmp = _pWorkChainHead;

			for (int j = 0; j < i; ++j) {
				pTmp = pTmp->next; //lint !e613,此处不会超出链表，所以不需要空指针判断
			}

			return pTmp;
		}

		bool empty() {
			return NULL == _pWorkChainHead;
		}

		int getSize() const {
			return _workNum;
		}

		void resetHead(NodeObject<T>* pHead) {
			_pWorkChainHead = pHead;
		}

		void resetTail(NodeObject<T>* pTail) {
			_pWorkChainTail = pTail;
		}

		//
	private:
		// 分配一个指针
		NodeObject<T>* alloc() {
			// 检查回收链是否有
			NodeObject<T>* pTmp = _pRecuChainTail;

			if (pTmp != NULL) {
				_pRecuChainTail = pTmp->prev;

				if (_pRecuChainTail != NULL) {
					_pRecuChainTail->next = NULL;
				}

				pTmp->prev = NULL;
				pTmp->next = NULL;
				return pTmp;
			}

			// new 一个
			int allocNum = 3;

			do {
				try {
					pTmp = new NodeObject<T>();

				}
				catch (std::bad_alloc& e) {
					if (allocNum-- < 0) {
						throw;
					}
				}
			} while (NULL == pTmp);

			return pTmp;
		}

		// 回收一个
		void recu(NodeObject<T>* pTr) {
			if (NULL == pTr) {
				return;
			}

			pTr->prev = NULL;
			pTr->next = NULL;

			if (NULL == _pRecuChainTail) {
				_pRecuChainTail = pTr;

			}
			else {
				_pRecuChainTail->next = pTr;
				pTr->prev = _pRecuChainTail;
				_pRecuChainTail = pTr;
			}
		}

	public:
		// 删除内存
		void delAll() {
			clear();

			NodeObject<T>* pTmp = NULL;

			while (_pRecuChainTail != NULL) {
				pTmp = _pRecuChainTail;
				_pRecuChainTail = pTmp->prev;
				delete pTmp;
			}
		}

	private:
		NodeObject<T>* _pWorkChainHead; // 工作链头
		NodeObject<T>* _pWorkChainTail; // 工作链尾
		NodeObject<T>* _pRecuChainTail; // 回收链尾
		NodeObject<T>* _pNextChainHead; //
		NodeObject<T>* _pNextCurObj;
		int            _workNum;        // 工作链的节点个数
	};

	// 按照指定的函数对链进行排序
	typedef bool(*SortChainFunc)(void* l, void* r);

	/**
	* 基于数据内容交换排序, 如果数据内容结构小且简单，用这个
	*
	* @param s, 链表对象
	* @param f, 排序方法
	*/
	template <typename T>
	inline void sortSwitchData(SortChain<T>& s, SortChainFunc f) {
		// 找到链头
		NodeObject<T>* firstPtr = s.first();
		NodeObject<T>* curPtr;
		T              tmpObj;

		// 循环比较
		for (; firstPtr; firstPtr = firstPtr->next) {
			curPtr = firstPtr->next;

			while (curPtr) {
				if (f(&(curPtr->obj), &(firstPtr->obj))) { // 条件满足交换值
					tmpObj = curPtr->obj;
					curPtr->obj = firstPtr->obj;
					firstPtr->obj = tmpObj;
				}

				curPtr = curPtr->next;
			}
		}
	}

	/**
	* 基于数据对应的位置交换, 如果数据内容结构大且复杂，用这个
	* 并且只是对整个链表中的某一段进行排序
	*
	* @param s, 链表对象
	* @param firstPtr，参与排序的链头
	* @param lastPtr,  参与排序的链尾
	* @param f, 排序方法
	*/
	template <typename T>
	inline void sortSegSwitchPos(SortChain<T>& s, NodeObject<T>* firstPtr, NodeObject<T>* lastPtr, SortChainFunc f) {
		bubbleSort(s, firstPtr, lastPtr, f);
	}

	// 冒泡排序
	template <typename T>
	inline void bubbleSort(SortChain<T>& s, NodeObject<T>* firstPtr, NodeObject<T>* lastPtr, SortChainFunc f) {
		NodeObject<T>* curPtr = NULL;
		NodeObject<T>* firstPrev = NULL;
		NodeObject<T>* firstNext = NULL;
		NodeObject<T>* curPrev = NULL;
		NodeObject<T>* curNext = NULL;
		NodeObject<T>* tmpPtr = NULL;
		NodeObject<T>* splitPtr = lastPtr ? lastPtr->next : NULL;

		// 循环比较
		for (; firstPtr && firstPtr != splitPtr; firstPtr = firstPtr->next) {
			curPtr = firstPtr->next;

			if (curPtr == splitPtr) {
				break;
			}

			while (curPtr) {
				if (f(&(curPtr->obj), &(firstPtr->obj))) { // 条件满足交换值
					firstPrev = firstPtr->prev;
					firstNext = firstPtr->next;
					curPrev = curPtr->prev;
					curNext = curPtr->next;

					// 基点的前一个节点
					if (firstPrev) {
						firstPrev->next = curPtr;
					}

					curPtr->prev = firstPrev;

					// 基点的下一个节点
					if (firstNext != curPtr) {
						firstNext->prev = curPtr;
					}

					curPtr->next = (firstNext != curPtr) ? firstNext : firstPtr;

					// 比较点的前一个节点
					if (curPrev != firstPtr) {
						curPrev->next = firstPtr;
					}

					firstPtr->prev = (curPrev != firstPtr) ? curPrev : curPtr;

					// 比较点的后一个节点
					if (curNext) {
						curNext->prev = firstPtr;
					}

					firstPtr->next = curNext;

					// 链头需要变更
					if (NULL == firstPrev) {
						s.resetHead(curPtr);
					}

					// 链尾需要变更
					if (NULL == curNext) {
						s.resetTail(firstPtr);
					}

					// 调整链比较位置
					tmpPtr = firstPtr;
					firstPtr = curPtr;
					curPtr = tmpPtr;
				}

				//
				curPtr = curPtr->next;

				if (curPtr == splitPtr) {
					break;
				}
			}
		}
	}

	// 快速排序
	template <typename T>
	inline void quickSort(SortChain<T>& s, NodeObject<T>* firstPtr, NodeObject<T>* lastPtr, SortChainFunc f) {
		// 指针为空了，或者是同一个指针，则不需要排序
		if (NULL == firstPtr || NULL == lastPtr || firstPtr == lastPtr) {
			return;
		}

		// 保存变量
		NodeObject<T>* pLeftEnd = firstPtr->prev; // 当前排序段的前一个指针
		NodeObject<T>* pRightFirst = lastPtr->next;  // 当前排序段的后一个指针

													 // 排序后的3个关键节点
		NodeObject<T>* pLeftHead = NULL; // 排序后左侧的头
		NodeObject<T>* pRightTail = NULL; // 排序后右侧的尾
		NodeObject<T>* pBaseMid = NULL; // 基础指针，左侧的比他小，右侧的比他大

										// 1. 排序
		NodeObject<T>* pCurCmpPtr = firstPtr->next; // 从链表中获取比较的指针，从下一个开始
		NodeObject<T>* pRefPtr = NULL;           // 参考指针，就是基础指针的左边第一个，或者右边第一个
		NodeObject<T>* pNextPtr = NULL;

		// 2. 遍历比较
		pBaseMid = firstPtr;
		pBaseMid->prev = NULL;
		pBaseMid->next = NULL;

		while (pCurCmpPtr) {
			// 保存下一个指针
			pNextPtr = pCurCmpPtr->next;

			// 小于放左侧
			if (f(&(pCurCmpPtr->obj), &(pBaseMid->obj))) {
				if (NULL == pLeftHead) {
					pLeftHead = pCurCmpPtr;
				}

				// 挂链
				pRefPtr = pBaseMid->prev;

				if (NULL != pRefPtr) {
					pRefPtr->next = pCurCmpPtr;
				}

				pCurCmpPtr->prev = pRefPtr;
				pCurCmpPtr->next = pBaseMid;
				pBaseMid->prev = pCurCmpPtr;

			}
			else { //大于放右侧
				if (NULL == pRightTail) {
					pRightTail = pCurCmpPtr;
				}

				// 挂链
				pRefPtr = pBaseMid->next;

				if (NULL != pRefPtr) {
					pRefPtr->prev = pCurCmpPtr;
				}

				pCurCmpPtr->prev = pBaseMid;
				pCurCmpPtr->next = pRefPtr;
				pBaseMid->next = pCurCmpPtr;
			}

			// 已经是最后一个指针
			if (pCurCmpPtr == lastPtr) {
				break;
			}

			// 比较下一个
			pCurCmpPtr = pNextPtr;
		}

		// 3. 判断基础链左右侧是否有链
		bool bNoLeftOut = false; // 无左侧链
		bool bNoRightOut = false; // 无右侧链

		if (NULL == pLeftHead) {
			bNoLeftOut = true;
			pLeftHead = pBaseMid;
		}

		if (NULL == pRightTail) {
			bNoRightOut = true;
			pRightTail = pBaseMid;
		}

		// 4. 和外围的大链关联起来
		pLeftHead->prev = pLeftEnd;

		if (NULL != pLeftEnd) {
			pLeftEnd->next = pLeftHead;
		}

		pRightTail->next = pRightFirst;

		if (NULL != pRightFirst) {
			pRightFirst->prev = pRightTail;
		}

		// 5. 重新定位链首和链尾
		if (NULL == pLeftHead->prev) {
			s.resetHead(pLeftHead);
		}

		if (NULL == pRightTail->next) {
			s.resetTail(pRightTail);
		}

		// 6. 递归排序
		if (!bNoLeftOut && pLeftHead != pBaseMid->prev) {
			quickSort(s, pLeftHead, pBaseMid->prev, f);
		}

		if (!bNoRightOut && pBaseMid->next != pRightTail) {
			quickSort(s, pBaseMid->next, pRightTail, f);
		}
	}

	/**
	* SortChain通过Vector来排序，但是需要注意以下问题：
	* 1. T 本身不能包含SortChain
	* 2. 如果 1 成立，请对T实现 operator = 方法，以防止内存 coredump
	*/

	template <typename T>
	inline void sortByVector(SortChain<T>& s, bool(*f)(const T& l, const T& r)) {
		std::vector<T> vs;

		if (s.getSize() <= 1) {
			return;
		}

		vs.reserve(s.getSize());    // 一次性分配好期望的空间

		s.rewind();

		while (s.next()) {
			vs.push_back(s.get());
		}

		std::sort(vs.begin(), vs.end(), f);

		s.clear();

		for (int i = vs.size() - 1; i >= 0; i--) {
			s.push_front(vs[i]);
		}
	}

	// 通过Vector排序，使用指针排序，减少对象拷贝时间
	template <typename T>
	inline void sortPtrByVector(SortChain<T>& s, bool(*f)(const NodeObject<T>* l, const NodeObject<T>* r) = NULL) {
		if (s.getSize() <= 1) {
			return;
		}

		std::vector<NodeObject<T>* > vec;
		vec.reserve(s.getSize());    // 一次性分配好期望的空间

									 // 把指针放入Vector
		NodeObject<T>* curPtr;
		curPtr = s.first();

		while (curPtr) {
			vec.push_back(curPtr);
			curPtr = curPtr->next;
		}

		// 排序函数
		struct myObjSort {
			static inline bool cmpNodePrt(const NodeObject<T>* l, const NodeObject<T>* r) {
				return l->obj < r->obj;
			}
		};

		if (NULL != f) {
			std::sort(vec.begin(), vec.end(), f);

		}
		else {
			std::sort(vec.begin(), vec.end(), myObjSort::cmpNodePrt);
		}

		// 把排好的指针重新组织起来
		NodeObject<T>* pHead = vec[0];
		NodeObject<T>* pTail = vec[vec.size() - 1];

		pHead->prev = NULL;
		pHead->next = NULL;
		pTail->prev = NULL;
		pTail->next = NULL;

		//
		curPtr = pHead;

		for (int i = 1; i < vec.size(); ++i) {
			curPtr->next = vec[i];
			vec[i]->prev = curPtr;
			curPtr = vec[i];
		}

		// 重置链头和链尾
		s.resetHead(pHead);
		s.resetTail(pTail);

		vec.clear();
	}

	/**
	* 基于数据对应的位置交换, 如果数据内容结构大且复杂，用这个
	*
	* @param s, 链表对象
	* @param f, 排序方法
	*/
	template <typename T>
	inline void sortSwitchPos(SortChain<T>& s, SortChainFunc f) {
		// 找到链头
		NodeObject<T>* firstPtr = s.first();
		NodeObject<T>* lastPtr = s.last();
		sortSegSwitchPos(s, firstPtr, lastPtr, f);
	}

	template <typename T>
	inline void clear(SortChain<T>& s) {
		s.rewind();

		while (s.next()) {
			T& t = const_cast<T&>(s.get());
			t.reset();
		}

		s.clear();
	}

} // namesapace
#endif

using namespace std;
using namespace util;

void ff()
{
	SortChain<int> iTest;
	int a = 123;
	int b = 456;
	iTest.push_back(a);
	iTest.push_back(b);
	return;
}

void gg()
{
	SortChain<int> iTest;
	int a = 123;
	int b = 456;
	iTest.push_back(a);
	iTest.push_back(b);
	iTest.rewind();
	while (iTest.next())
	{
		cout << iTest.get() << endl;
	}
}

int  main()
{
	gg();
	getchar();
	return 0;
}

猜你喜欢

转载自my.oschina.net/pirtt/blog/1806657
JJ