欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于雙向鏈表的增刪改查和排序的C++實(shí)現(xiàn)

 更新時(shí)間:2016年12月18日 12:53:22   投稿:jingxian  
下面小編就為大家?guī)硪黄P(guān)于雙向鏈表的增刪改查和排序的C++實(shí)現(xiàn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

雙向鏈表也叫雙鏈表,是鏈表的一種,它的每個(gè)數(shù)據(jù)結(jié)點(diǎn)中都有兩個(gè)指針,分別指向直接后繼和直接前驅(qū)。所以,從雙向鏈表中的任意一個(gè)結(jié)點(diǎn)開始,都可以很方便地訪問它的前驅(qū)結(jié)點(diǎn)和后繼結(jié)點(diǎn)。一般我們都構(gòu)造雙向循環(huán)鏈表。

由于雙向鏈表可以方便地實(shí)現(xiàn)正序和逆序兩個(gè)方向的插入、查找等功能,在很多算法中經(jīng)常被使用,

這里用C++構(gòu)造了一個(gè)雙向鏈表,提供了對雙向鏈表的插入、查找、刪除節(jié)點(diǎn)、排序等功能,其中排序提供了插入排序和冒泡排序兩種方式

#include<iostream>

using namespace std;

class Node     //組成雙向鏈表的節(jié)點(diǎn)
{
public:
  int data;
  Node * pNext;
  Node * pLast;
};

class List   //構(gòu)造一個(gè)雙向鏈表
{
private:
  Node * pHead;
  Node * pTail;
  int length;
public:
  List(int length)    //創(chuàng)建雙向鏈表
  {
    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)    //修改鏈表中指定位置的節(jié)點(diǎn)
  {
    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)    //插入數(shù)據(jù)
  {
    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)   //刪除指定位置的節(jié)點(diǎn)
  {
    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)      //查找指定位置的節(jié)點(diǎn)
  {
    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;
}

以上這篇關(guān)于雙向鏈表的增刪改查和排序的C++實(shí)現(xiàn)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++深入探究不同的繼承體系

    C++深入探究不同的繼承體系

    繼承是C++面向?qū)ο缶幊讨械囊婚T。繼承是子類繼承父類的特征和行為,或者是繼承父類得方法,使的子類具有父類得的特性和行為。重寫是子類對父類的允許訪問的方法實(shí)行的過程進(jìn)行重新編寫,返回值和形參都不能改變。就是對原本的父類進(jìn)行重新編寫,但是外部接口不能被重寫
    2022-05-05
  • C語言實(shí)現(xiàn)排序算法之歸并排序詳解

    C語言實(shí)現(xiàn)排序算法之歸并排序詳解

    這篇文章主要介紹了C語言實(shí)現(xiàn)排序算法之歸并排序,對歸并排序的原理及實(shí)現(xiàn)過程做了非常詳細(xì)的解讀,需要的朋友可以參考下
    2014-07-07
  • C語言實(shí)現(xiàn)動態(tài)順序表的示例代碼

    C語言實(shí)現(xiàn)動態(tài)順序表的示例代碼

    順序表是用一段物理地址連續(xù)的存儲單元依次存儲數(shù)據(jù)元素的線性結(jié)構(gòu)。順序表一般分為靜態(tài)順序表和動態(tài)順序表,本文主要和大家介紹的是動態(tài)順序表的實(shí)現(xiàn),需要的可以參考一下
    2022-10-10
  • C++實(shí)現(xiàn)遞歸函數(shù)的方法

    C++實(shí)現(xiàn)遞歸函數(shù)的方法

    在本篇內(nèi)容里小編給大家分享了關(guān)于C++實(shí)現(xiàn)遞歸函數(shù)的教學(xué)步驟,需要的朋友跟著參考下。
    2018-12-12
  • C++ windows LOG4plus的使用小結(jié)

    C++ windows LOG4plus的使用小結(jié)

    這篇文章主要介紹了C++ windows LOG4plus的使用小結(jié),本文通過圖文示例代碼相結(jié)合給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • C++實(shí)現(xiàn)批量提取PDF內(nèi)容

    C++實(shí)現(xiàn)批量提取PDF內(nèi)容

    這篇文章主要為大家詳細(xì)介紹了如何使用C++批量提取PDF里文字內(nèi)容并導(dǎo)出到表格以及批量給?PDF?文件改名,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2025-02-02
  • C++?超詳細(xì)分析數(shù)據(jù)結(jié)構(gòu)中的時(shí)間復(fù)雜度

    C++?超詳細(xì)分析數(shù)據(jù)結(jié)構(gòu)中的時(shí)間復(fù)雜度

    時(shí)間復(fù)雜度一般指時(shí)間復(fù)雜性。?在計(jì)算機(jī)科學(xué)中,時(shí)間復(fù)雜性,又稱時(shí)間復(fù)雜度,算法的時(shí)間復(fù)雜度是一個(gè)函數(shù),它定性描述該算法的運(yùn)行時(shí)間
    2022-03-03
  • VisualStudio2022打包項(xiàng)目文件為.exe安裝包

    VisualStudio2022打包項(xiàng)目文件為.exe安裝包

    本文主要介紹了VisualStudio2022打包項(xiàng)目文件為.exe安裝包,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • C語言程序環(huán)境和預(yù)處理詳解分析

    C語言程序環(huán)境和預(yù)處理詳解分析

    大家有沒有想過,在vs2019的編譯器上只要按下Ctrl+F5,一個(gè)test.c的源程序就能變成一個(gè).exe的可執(zhí)行程序,這其中是如何通過編譯產(chǎn)生的呢,本章就和大家一起把其中的知識和重點(diǎn)的預(yù)處理一起學(xué)習(xí)一下
    2022-03-03
  • matlab鳥群算法求解車間調(diào)度問題詳解及實(shí)現(xiàn)源碼

    matlab鳥群算法求解車間調(diào)度問題詳解及實(shí)現(xiàn)源碼

    這篇文章主要為大家介紹了matlab鳥群算法求解車間調(diào)度的問題分析及實(shí)現(xiàn)源碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-02-02

最新評論