国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

關于雙向鏈表的增刪改查和排序的C++實現

2020-01-26 14:21:45
字體:
來源:轉載
供稿:網友

雙向鏈表也叫雙鏈表,是鏈表的一種,它的每個數據結點中都有兩個指針,分別指向直接后繼和直接前驅。所以,從雙向鏈表中的任意一個結點開始,都可以很方便地訪問它的前驅結點和后繼結點。一般我們都構造雙向循環鏈表

由于雙向鏈表可以方便地實現正序和逆序兩個方向的插入、查找等功能,在很多算法中經常被使用,

這里用C++構造了一個雙向鏈表,提供了對雙向鏈表的插入、查找、刪除節點、排序等功能,其中排序提供了插入排序和冒泡排序兩種方式

#include<iostream>using namespace std;class Node     //組成雙向鏈表的節點{public:  int data;  Node * pNext;  Node * pLast;};class List   //構造一個雙向鏈表{private:  Node * pHead;  Node * pTail;  int length;public:  List(int length)    //創建雙向鏈表  {    this->length=length;    pHead=new Node();    pHead->pLast=NULL;    pTail=pHead;    for(int i=0;i<length;i++)    {      Node * temp=new Node();      cout<<"please enter the no"<<i+1<<" Node's data:";      cin>>temp->data;      temp->pNext=NULL;      temp->pLast=pTail;      pTail->pNext=temp;      pTail=temp;    }  }    void traverseList()    //正向遍歷  {    Node * p=pHead->pNext;    while(p!=NULL)    {      cout<<p->data<<endl;      p=p->pNext;    }  }    void traverseListReturn()    //逆向遍歷  {    Node * p=pTail;    while(p->pLast!=NULL)    {      cout<<p->data<<endl;      p=p->pLast;    }  }    void sortList()   //冒泡排序  {    Node * p=new Node();    Node * q=new Node();    int temp;    for(p=pHead->pNext;p->pNext!=NULL;p=p->pNext)    {      for(q=p->pNext;q!=NULL;q=q->pNext)      {        if(q->data<p->data)        {          temp=q->data;          q->data=p->data;          p->data=temp;        }      }    }  }    void sortListByInsertWay()    //插入排序  {    if(pHead->pNext==NULL||pHead->pNext->pNext==NULL)    {      return;    }    Node * p2=pHead->pNext->pNext;    Node * p1=pHead;    pHead->pNext->pNext=NULL;    while(p2)    {      Node * pN=p2->pNext;      while(p1->pNext)      {        if(p2->data<p1->pNext->data)        {          p2->pNext=p1->pNext;          p2->pLast=p1;          p1->pNext->pLast=p2;          p1->pNext=p2;          break;        }        p1=p1->pNext;      }      if(p1->pNext==NULL)      {        p2->pNext=NULL;        p2->pLast=p1;        p1->pNext=p2;      }      p2=pN;    }        //重新查找pTail的位置    Node * pt=pHead;    while(pt->pNext)    {      pt=pt->pNext;    }    pTail=pt;  }    void changeList(int num,int position)    //修改鏈表中指定位置的節點  {    Node * p=pHead->pNext;    if(position>length||position<=0)    {      cout<<"over stack !"<<endl;      return;    }    for(int i=0;i<position-1;i++)    {      p=p->pNext;    }    p->data=num;  }    void insertList(int num,int position)    //插入數據  {    Node * p=pHead->pNext;    if(position>length||position<=0)    {      cout<<"over stack !"<<endl;      return;    }    for(int i=0;i<position-1;i++)    {      p=p->pNext;    }    Node * temp=new Node();    temp->data=num;    temp->pNext=p;    temp->pLast=p->pLast;    p->pLast->pNext=temp;    p->pLast=temp;    length++;  }    void clearList()      //清空  {    Node * q;    Node * p=pHead->pNext;    while(p!=NULL)    {      q=p;      p=p->pNext;      delete q;    }    p=NULL;    q=NULL;  }    void deleteList(int position)   //刪除指定位置的節點  {    Node * p=pHead->pNext;    if(position>length||position<=0)    {      cout<<"over stack !"<<endl;      return;    }    for(int i=0;i<position-1;i++)    {      p=p->pNext;    }    p->pLast->pNext=p->pNext;    p->pNext->pLast=p->pLast;    delete p;    length--;  }    int getItemInList(int position)      //查找指定位置的節點  {    Node * p=pHead->pNext;    if(position>length||position<=0)    {      cout<<"over stack !"<<endl;      return 0;    }    for(int i=0;i<position-1;i++)    {      p=p->pNext;    }    return p->data;  }    ~List()  {    Node * q;    Node * p=pHead->pNext;    while(p!=NULL)    {      q=p;      p=p->pNext;      delete q;    }    p=NULL;    q=NULL;  }  };int main(){  List l(3);  l.traverseList();  cout<<"AFTER SORT------------------------------------------------------"<<endl;//  l.sortList();       //冒泡排序  l.sortListByInsertWay();  //插入排序  l.traverseList();  cout<<"AFTER INSERT-----------------------------------------------------"<<endl;  l.insertList(55,1);  l.traverseList();  cout<<"AFTER DELETE-----------------------------------------------------"<<endl;  l.deleteList(1);  l.traverseList();  cout<<"Return Traverse---------------------------------------------"<<endl;  l.traverseListReturn();  cout<<"Find the Second Node's data:"<<l.getItemInList(2)<<endl;  return 0;}

以上這篇關于雙向鏈表的增刪改查和排序的C++實現就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 白朗县| 临清市| 峨边| 林口县| 侯马市| 台北市| 原平市| 衡阳县| 德令哈市| 郯城县| 海兴县| 建宁县| 轮台县| 玛纳斯县| 凉山| 宜昌市| 桓台县| 鄢陵县| 东港市| 东乌珠穆沁旗| 清涧县| 峨边| 铜陵市| 乃东县| 鱼台县| 林西县| 宿迁市| 赣榆县| 永嘉县| 新泰市| 长治市| 额济纳旗| 天祝| 阆中市| 五指山市| 惠州市| 同心县| 安陆市| 维西| 石家庄市| 游戏|