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

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

用C++類實(shí)現(xiàn)單向鏈表的增刪查和反轉(zhuǎn)操作方法

2020-01-26 14:11:16
字體:
供稿:網(wǎng)友

數(shù)據(jù)結(jié)構(gòu)這東西,理解起來不算難,但是實(shí)現(xiàn)難度就不小了,雖然思路很清晰,但不知道從何下手還有語言的細(xì)節(jié)問題一直是阻礙初學(xué)者的主要障礙(比如我)。今天用了一下午時間終于獨(dú)立完成了鏈表操作。

找網(wǎng)上的代碼,大多用了結(jié)構(gòu)體,還有些并不適合剛學(xué)c++或者數(shù)據(jù)結(jié)構(gòu)的人看,于是我是用類寫的,代碼比較符合學(xué)生的習(xí)慣和水平。

先看類定義

class node{public:  int data;  node *next;};class linklist{  node *h;  ……//一些函數(shù)}

兩個類,node用來表示結(jié)點(diǎn),node *next,表示next是指向node型的指針(一些同學(xué)看不懂這句,會和構(gòu)造函數(shù)弄混),linklist類是存放頭指針和定義操作函數(shù)用的。

一、整表的創(chuàng)建

整表創(chuàng)建有兩種方法,頭插(倒敘)和尾插(順序),這里只說頭插。

void head(linklist &l,int n)  {    node *p;    p=new node;    l.h=p;//定義頭結(jié)點(diǎn)和投指針    p->data=n;//頭指針的數(shù)據(jù)域是結(jié)點(diǎn)個數(shù)    p->next=NULL;//最末結(jié)點(diǎn)的后繼必須為空    for(int i=0;i<n;i++)//創(chuàng)建n個新結(jié)點(diǎn)    {      node *q=new node;      cin>>q->data;      q->next=p->next;      p->next=q;//每個新結(jié)點(diǎn)都放在頭結(jié)點(diǎn)后面    }  }

二、單結(jié)點(diǎn)插入

void insert(linklist &l,int n,int num)  {    node *p=l.h;    for(int i=0;i<n;i++)    {      p=p->next;    }//找到插入的位置    node *q=new node;    q->next=p->next;    p->next=q;    q->data=num;  }

三、單結(jié)點(diǎn)刪除

void del(linklist &l,int n)  {    node *p=l.h;    for(int i=0;i<n-1;i++)    {      p=p->next;    }//找到刪除的位置    node *q=p;    q=q->next;    p->next=q->next;    delete q;//釋放空間  }

四、查找結(jié)點(diǎn)

void search(linklist &l,int n)  {    node *p=l.h;    for(int i=0;i<n;i++)    {      p=p->next;    }    cout<<p->data<<endl;  }

五、倒置

由于頭插是倒敘輸出,就想倒置,網(wǎng)上好多代碼都是新建一個鏈表,或者用到尾指針雙向鏈表之類,我覺得不會這么麻煩于是就想了這么個算法

void reverse(linklist l)  {    node *p=l.h;    node *q;    p=p->next;    while(p->next)    {     q=p->next;     p->next=q->next;    // q->next=p;  //如果把下面兩句換成這句,就會悲劇。     q->next=l.h->next;     l.h->next=q;    }  }

一下午時間主要就耽誤在這里了,我一開始寫的就是注釋那句話,后來總是輸出頭結(jié)點(diǎn)的數(shù)據(jù),仔細(xì)觀察發(fā)現(xiàn)原來是頭指針跟著頭結(jié)點(diǎn)換到了最后面,然后這個問題通過下面兩句解決,保證頭指針永遠(yuǎn)在表頭。

六、結(jié)語

寫到這里,終于明白為什么網(wǎng)上包括書上很多代碼都是看懂容易寫起來難,因?yàn)闀蛘卟┛妥髡呔筒粫阉高^的錯誤貼出來,一些簡單的代碼也沒有很多注釋,自己寫的時候也理解他們了,想詳細(xì)寫出每一步的理由還是太難了,無法表達(dá)的東西太多,所以想掌握一個東西還是親手實(shí)踐,多犯錯誤才能進(jìn)步,因?yàn)闀匣蚓W(wǎng)上很難找到細(xì)節(jié)之處易犯的錯誤,以為自己會了的時候就用紙寫出來,到頭來會發(fā)現(xiàn)還是不會……循環(huán)幾次,就差不多了。

以上這篇用C++類實(shí)現(xiàn)單向鏈表的增刪查和反轉(zhuǎn)操作方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 扶绥县| 全南县| 遵义县| 福鼎市| 兴文县| 临安市| 八宿县| 德安县| 霸州市| 阿拉善盟| 张家口市| 水城县| 皋兰县| 晋江市| 蓬溪县| 西安市| 桐柏县| 营口市| 剑河县| 长葛市| 双峰县| 黄骅市| 丁青县| 大同县| 旬阳县| 鞍山市| 侯马市| 兴业县| 沂水县| 甘泉县| 灵山县| 二手房| 合川市| 铜川市| 阜城县| 桦南县| 南宫市| 思茅市| 开阳县| 炎陵县| 阿拉善左旗|