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

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

?? linkedlist.h

?? 一個進(jìn)行整數(shù)計算的C語言詞法分析器
?? H
字號:
#include "Node.h"
#include "stdlib.h"

template<class T>
class LinkedList
{
	Node<T>*front,*rear;                                    //一個頭指針和一個尾指針
	Node<T>*prevPtr,*currPtr;                               //前指針和當(dāng)前指針
	int size,position;                                      //鏈表長度    和 當(dāng)前位置
	Node<T>*GetNode(const T&item,Node<T>*ptrNext=NULL);      //得到一個節(jié)點
	void FreeNode(Node<T>*p);                               //釋放節(jié)點
	void CopyList(const LinkedList<T>&L);                   //復(fù)制鏈表
public:
	LinkedList(void);                                       //無參構(gòu)造函數(shù)
	LinkedList(const LinkedList <T>&L);                     //有參構(gòu)造函數(shù)
	~LinkedList(void);                                      //析構(gòu)函數(shù)
	LinkedList<T>& operator=(const LinkedList<T>&L);        //重載賦值符號
	int ListSize(void)const;                          //取鏈表長度
	int ListEmpty(void)const;                         //判斷鏈表是不是空
	void Reset(int pos=0);                            //把當(dāng)前指針重置在鏈表的頭
	void Next(void);                                  //把當(dāng)前指針移到下一個   
	int EndOfList(void)const;                         //判斷是否是鏈表的尾
	int CurrentPosition(void)const;                   //求當(dāng)前指針的位置
	void InsertFront(const T&item);                    //插入頭        
	void InsertRear(const T&item);                    //插入尾
	void InsertAt(const T&item);                      //插在當(dāng)前位置
	void InsertAfter(const T&item);                   //插在當(dāng)前節(jié)點后面
	T DeleteFront(void);                              //去掉頭指針
	void DeleteAt(void);                              //去掉當(dāng)前指針
	T& Data(void);                                    //取this指針中的數(shù)據(jù)
	void ClearList(void);                             //清空指針
};

template <class T>
LinkedList<T>::LinkedList(void):   
          front(NULL), rear(NULL),prevPtr(NULL),
		  currPtr(NULL),size(0),position(-1){}


template <class T>
Node<T> * LinkedList<T>::GetNode(const T& item,Node<T>* ptrNext)
{
       Node<T> *p;
       p = new Node<T>(item, ptrNext);
       if (p == NULL)
       {      
		   cout << "Memory allocation failure!\n";
           exit(1);
       }
      return p;
}

template <class T>
LinkedList<T>::LinkedList(const LinkedList<T>& L)
{
   front = rear = NULL;
   prevPtr = currPtr = NULL;
   size = 0;
   position = -1;
   CopyList(L);
}

template <class T>
void LinkedList<T>::FreeNode(Node<T> *p)
{
   delete p;
}

template <class T>
void LinkedList<T>::CopyList(const LinkedList<T>& L)
{   
	// use p to chain through L
    Node<T> *p = L.front;   int  pos;
    // insert each element in L at the rear of current object
    while (p != NULL)
    {  
		InsertRear(p->data);   
		p = p->NextNode( );  
	}
    if (position == -1) return;   // if list is empty return
    // reset prevPtr and currPtr in the new list
    prevPtr = NULL;   currPtr = front;
    for (pos = 0; pos != position; pos++)
    {  
		prevPtr = currPtr;
        currPtr = currPtr->NextNode( ); 
	}
}
template <class T>
void LinkedList<T>::ClearList(void)
{  
	Node<T> *currPosition, *nextPosition;
    currPosition = front;
    while(currPosition != NULL)
    {  
		// get address of next node and delete current node
        nextPosition = currPosition->NextNode( );
        FreeNode(currPosition);
        currPosition = nextPosition;  // Move to next node 
	}
    front = rear = NULL;
    prevPtr = currPtr = NULL;
    size = 0;   
	position = -1;
}

template <class T>
LinkedList<T>::~LinkedList(void)
{
	ClearList( );
}
template <class T>
LinkedList<T>& LinkedList<T>::operator= 
               (const LinkedList<T>& L)
{
   if (this == &L)      // Can't assign list to itself
        return *this;
   ClearList( );
   CopyList(L);
   return *this;
}

template <class T>
int LinkedList<T>::ListSize(void) const
{
   return size;
}
template <class T>
int LinkedList<T>::ListEmpty(void) const
{
   return size == 0;
}
template <class T>
void LinkedList<T>::Next(void)
{  // if traversal has reached the end of the list or
   // the list is empty, just return
   if (currPtr != NULL)
   { // advance the two pointers one node forward
      prevPtr = currPtr;
      currPtr = currPtr->NextNode( );
      position++;
   }
}

template <class T>
int LinkedList<T>::EndOfList(void) const
{
   return currPtr == NULL;
}
template <class T>
int LinkedList<T>::CurrentPosition(void) const
{
   return position;
}

template <class T>
void LinkedList<T>::Reset(int pos)
{   
	int startPos;     
	if (front == NULL) return;
    if (pos < 0 || pos > size-1) 
    { 
		cerr << "Reset: Invalid list position: " <<pos << endl;            
		return;  
	}
    if(pos == 0)  
    {
		prevPtr = NULL;   
		currPtr = front;     
		position = 0;   
	}
    else 
	{  
		currPtr = front->NextNode( );  
		prevPtr = front;  
        startPos = 1;
		for(position=startPos; position != pos; position++)
        { 
			prevPtr = currPtr;  
			currPtr = currPtr->NextNode( );
        }
     }
}
template <class T>
T& LinkedList<T>::Data(void)
{
   // error if list is empty or traversal completed
   if (size == 0 || currPtr == NULL)
   {
      cerr << "Data: invalid reference!" << endl;
      exit(1);
   }
   return currPtr->data;
}
template <class T>
void LinkedList<T>::InsertAt(const T& item)
{   
	Node<T> *newNode;
    if (prevPtr == NULL)
    { 
		newNode = GetNode(item, front);
        front = newNode;   
	}
   else  
   {
	   newNode = GetNode(item);
       prevPtr->InsertAfter(newNode);   
   }
   if (prevPtr == rear)
   {
	   rear = newNode; 
	   position = size;   
   }
   currPtr = newNode;   
   size++;
}
template <class T>
void LinkedList<T>::InsertFront(const T& item)
{
      // call Reset if the list is not empty
      if (front != NULL)
           Reset( );
      InsertAt(item);        // inserts at front
}
template <class T>
void LinkedList<T>::InsertAfter(const T& item)
{   
	Node<T> *p;   
	p = GetNode(item);
    if (front == NULL)       // inserting into an empty list
    {  
		front = currPtr = rear = p;   
		position = 0;   
	}
   else 
   {  
	   if (currPtr == NULL)  currPtr = prevPtr;
       currPtr->InsertAfter(p);
       if (currPtr == rear)
	   {
		   rear = p;   
		   position = size;
	   }
       else  position++;  
        prevPtr = currPtr;   
		currPtr = p;   
   }
   size++;              // increment list size
}
template <class T>
void LinkedList<T>::InsertRear(const T& item)
{  
	Node<T> *newNode;
    prevPtr = rear;
    newNode = GetNode(item);	// create the new node
    if (rear == NULL) // if list empty, insert at front
      front=rear = newNode;
    else 
	{ 
		rear->InsertAfter(newNode);  
        rear = newNode;  
	}
    currPtr = rear;   
	position = size;   
	size++;
}
template <class T>
void LinkedList<T>::DeleteAt(void)
{   
	Node<T> *p;
    if (currPtr == NULL)
    { 
		cerr << "Invalid deletion!" << endl; 
		exit(1);
	}
   if (prevPtr == NULL)
   {
	   p = front;   
	   front = front->NextNode( );
   }
   else  p = prevPtr->DeleteAfter( );
   if (p == rear)  
   {  
	   rear = prevPtr;  
	   position--;  
   }
   currPtr = p->NextNode( );  
   FreeNode(p);   
   size--;
}

template <class T>
T LinkedList<T>::DeleteFront(void)
 {   
	T item;
    Reset( );
    if (front == NULL)
    { 
		cerr << "Invalid deletion!" << endl;
        exit(1);   
	}
    item = currPtr->data;
    DeleteAt( );
    return item;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲最大成人综合| 成人免费视频一区| 国产美女久久久久| 欧美日韩国产小视频在线观看| 精品处破学生在线二十三| 亚洲视频 欧洲视频| 久草精品在线观看| 欧美亚洲一区三区| 亚洲色图视频免费播放| 蜜臀av性久久久久蜜臀aⅴ四虎| 99久久99久久综合| 久久精品免费在线观看| 日本欧美一区二区三区乱码| 99re亚洲国产精品| 国产女人18毛片水真多成人如厕| 天天综合色天天| 99国产精品视频免费观看| 久久久噜噜噜久噜久久综合| 免费观看在线综合色| 精品污污网站免费看| 亚洲综合久久av| www.亚洲色图| 国产精品家庭影院| 成人毛片老司机大片| 久久五月婷婷丁香社区| 久久99精品视频| 精品美女一区二区三区| 日本sm残虐另类| 欧美一区二区三区在线视频| 天天av天天翘天天综合网色鬼国产| 一本到不卡精品视频在线观看| 国产精品久久久久久久久免费相片| 国产suv精品一区二区三区| 久久久久一区二区三区四区| 国产原创一区二区三区| 国产无人区一区二区三区| 国产精品伊人色| 中文字幕av在线一区二区三区| 粉嫩av一区二区三区粉嫩| 国产日韩欧美一区二区三区乱码| 国产精品亚洲第一| 中文字幕免费不卡在线| 成人免费精品视频| 一区二区在线看| 在线观看91视频| 日韩av电影天堂| 精品久久久久久亚洲综合网 | 欧美性xxxxx极品少妇| 亚洲丝袜精品丝袜在线| 日本黄色一区二区| 天天做天天摸天天爽国产一区| 91精品国产一区二区三区香蕉| 久久99热国产| 1024成人网| 欧美群妇大交群中文字幕| 美女网站一区二区| 国产欧美久久久精品影院| 91亚洲国产成人精品一区二区三| 亚洲综合在线观看视频| 欧美一区二区性放荡片| 国产精品 日产精品 欧美精品| 国产精品网友自拍| 欧美中文字幕一区| 久久电影网站中文字幕 | 中文天堂在线一区| 97国产一区二区| 日本aⅴ亚洲精品中文乱码| www国产精品av| 色欧美片视频在线观看| 青青草国产精品97视觉盛宴| 国产亚洲精久久久久久| 日本韩国一区二区三区| 国产一区二区伦理片| 亚洲欧美日韩精品久久久久| 日韩午夜激情av| 日本久久一区二区| 国产一区激情在线| 亚洲一二三专区| 国产精品免费网站在线观看| 欧美色欧美亚洲另类二区| 国产91在线|亚洲| 免费在线视频一区| 一区二区在线看| 国产精品乱码一区二区三区软件| 欧美精品久久天天躁| eeuss鲁片一区二区三区| 久热成人在线视频| 亚洲成人免费在线观看| 亚洲欧洲国产日韩| 国产亚洲午夜高清国产拍精品| 欧美揉bbbbb揉bbbbb| av高清久久久| 国产福利一区在线| 七七婷婷婷婷精品国产| 亚洲午夜精品网| 亚洲另类色综合网站| 国产精品沙发午睡系列990531| 精品久久人人做人人爱| 91精品国产综合久久久蜜臀粉嫩 | 久久嫩草精品久久久精品| 欧美日韩国产综合视频在线观看| 成人福利视频网站| 国产精品综合久久| 国产麻豆日韩欧美久久| 激情久久久久久久久久久久久久久久| 天使萌一区二区三区免费观看| 亚洲免费在线观看视频| 亚洲欧洲国产日韩| 亚洲欧洲美洲综合色网| 国产精品不卡一区二区三区| 国产日产精品1区| 久久精品夜色噜噜亚洲aⅴ| 精品国产1区2区3区| 亚洲精品一区二区三区99| 亚洲精品在线免费播放| 日韩精品在线网站| 亚洲精品一区二区三区99| 亚洲精品在线免费播放| 国产亚洲欧美日韩在线一区| 久久久久久亚洲综合| 久久综合久久鬼色| 久久精品一区二区三区不卡| 国产午夜精品美女毛片视频| 2024国产精品| 国产日韩视频一区二区三区| 欧美经典三级视频一区二区三区| 国产欧美精品区一区二区三区| 国产欧美日韩精品一区| 国产精品国产馆在线真实露脸| 亚洲欧美影音先锋| 亚洲影院久久精品| 秋霞电影网一区二区| 激情五月婷婷综合网| 成人污视频在线观看| 色播五月激情综合网| 69p69国产精品| 久久美女艺术照精彩视频福利播放 | 亚洲免费大片在线观看| 亚洲一区二区三区在线| 日韩av一区二区三区四区| 狠狠色狠狠色合久久伊人| 成人精品国产免费网站| 在线观看日韩国产| 日韩一级片网站| 国产精品国模大尺度视频| 亚洲午夜视频在线| 国产一区二区在线电影| 日本精品一区二区三区高清| 欧美精品成人一区二区三区四区| 精品久久久三级丝袜| 亚洲日本在线a| 日本怡春院一区二区| 国产成人在线免费| 欧美综合亚洲图片综合区| 日韩你懂的在线播放| 亚洲人吸女人奶水| 久久精品国产亚洲5555| 日本精品一区二区三区高清| 26uuuu精品一区二区| 亚洲激情中文1区| 狠狠色丁香九九婷婷综合五月| 日本国产一区二区| 亚洲精品一区在线观看| 亚洲激情自拍视频| 国产精品18久久久久久久久久久久 | 中文字幕不卡一区| 日韩一区精品字幕| 一本一道综合狠狠老| 精品国产免费一区二区三区四区| 亚洲欧美激情插| 东方aⅴ免费观看久久av| 91精品国产91综合久久蜜臀| 亚洲色图清纯唯美| 国产成人午夜精品影院观看视频| 在线不卡的av| 一区二区三区在线观看视频 | 2021久久国产精品不只是精品| 亚洲伦理在线精品| 成a人片国产精品| 精品国产区一区| 日本女人一区二区三区| 欧美又粗又大又爽| 亚洲欧洲一区二区在线播放| 国产精品18久久久久久久久 | 久久久久久免费| 男女激情视频一区| 欧美福利电影网| 亚洲va欧美va国产va天堂影院| 97久久超碰精品国产| 国产精品人妖ts系列视频| 国产一区美女在线| 久久综合色鬼综合色| 紧缚捆绑精品一区二区| 日韩欧美卡一卡二| 男女性色大片免费观看一区二区| 欧美日韩久久一区| 日韩国产精品久久久久久亚洲| 欧美中文字幕亚洲一区二区va在线 | 成人在线一区二区三区| 国产午夜精品理论片a级大结局 |