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

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

 更新時(shí)間:2017年04月11日 10:19:57   投稿:jingxian  
下面小編就為大家?guī)硪黄肅++類實(shí)現(xiàn)單向鏈表的增刪查和反轉(zhuǎn)操作方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

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

找網(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ù)
}

兩個(gè)類,node用來表示結(jié)點(diǎn),node *next,表示next是指向node型的指針(一些同學(xué)看不懂這句,會(huì)和構(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)個(gè)數(shù)
    p->next=NULL;//最末結(jié)點(diǎn)的后繼必須為空
    for(int i=0;i<n;i++)//創(chuàng)建n個(gè)新結(jié)點(diǎn)
    {
      node *q=new node;
      cin>>q->data;
      q->next=p->next;
      p->next=q;//每個(gè)新結(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)上好多代碼都是新建一個(gè)鏈表,或者用到尾指針雙向鏈表之類,我覺得不會(huì)這么麻煩于是就想了這么個(gè)算法

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;  //如果把下面兩句換成這句,就會(huì)悲劇。
     q->next=l.h->next;
     l.h->next=q;
    }
  }

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

六、結(jié)語

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

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

相關(guān)文章

  • C語言棧之順序棧

    C語言棧之順序棧

    這篇文章主要為大家詳細(xì)介紹了C語言的順序棧,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • C++中的friend友元函數(shù)詳細(xì)解析

    C++中的friend友元函數(shù)詳細(xì)解析

    友元可以是一個(gè)函數(shù),該函數(shù)被稱為友元函數(shù);友元也可以是一個(gè)類,該類被稱為友元類。友元函數(shù)的特點(diǎn)是能夠訪問類中的私有成員的非成員函數(shù)。友元函數(shù)從語法上看,它與普通函數(shù)一樣,即在定義上和調(diào)用上與普通函數(shù)一樣
    2013-09-09
  • C++中 Sort函數(shù)詳細(xì)解析

    C++中 Sort函數(shù)詳細(xì)解析

    這篇文章主要介紹了C++中 Sort函數(shù)詳細(xì)解析,sort函數(shù)是algorithm庫下的一個(gè)函數(shù),sort函數(shù)是不穩(wěn)定的,即大小相同的元素在排序后相對(duì)順序可能發(fā)生改變
    2022-08-08
  • C++實(shí)現(xiàn)簡易貪吃蛇游戲

    C++實(shí)現(xiàn)簡易貪吃蛇游戲

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡易貪吃蛇游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • C++實(shí)踐數(shù)組類運(yùn)算的實(shí)現(xiàn)參考

    C++實(shí)踐數(shù)組類運(yùn)算的實(shí)現(xiàn)參考

    今天小編就為大家分享一篇關(guān)于C++實(shí)踐數(shù)組類運(yùn)算的實(shí)現(xiàn)參考,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • C/C++數(shù)據(jù)對(duì)齊詳細(xì)解析

    C/C++數(shù)據(jù)對(duì)齊詳細(xì)解析

    通常我們在寫代碼的時(shí)候是不需要考慮對(duì)齊的影響的,都是依賴編譯器來為我們選擇適合的對(duì)齊策略,我們也可以通過傳遞給編譯器預(yù)編譯指令來指定數(shù)據(jù)對(duì)齊的方法
    2013-10-10
  • 簡單談?wù)凜++ 頭文件系列之(bitset)

    簡單談?wù)凜++ 頭文件系列之(bitset)

    我們要使用bitset,首先需要包含頭文件bitset。和vector對(duì)象不一樣的是bitset類型對(duì)象的區(qū)別僅在其長度而不在其類型。在定義bitset的時(shí)候,要明確bitset包含了多少位,須在尖括號(hào)內(nèi)給出它的長度值。長度值必須定義為整形字面值常量或是已用常量值初始化的整型的const對(duì)象
    2017-02-02
  • 字符串中找出連續(xù)最長的數(shù)字字符串的實(shí)例代碼

    字符串中找出連續(xù)最長的數(shù)字字符串的實(shí)例代碼

    這篇文章介紹了字符串中找出連續(xù)最長的數(shù)字字符串的實(shí)例代碼,有需要的朋友可以參考一下
    2013-09-09
  • C++11實(shí)現(xiàn)簡易定時(shí)器的示例代碼

    C++11實(shí)現(xiàn)簡易定時(shí)器的示例代碼

    這篇文章主要介紹了C++11實(shí)現(xiàn)簡易定時(shí)器的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • C語言詳解函數(shù)與指針的使用

    C語言詳解函數(shù)與指針的使用

    C語言這門課程在計(jì)算機(jī)的基礎(chǔ)教學(xué)中一直占有比較重要的地位,然而要想突破C語言的學(xué)習(xí),對(duì)函數(shù)和指針的掌握是非常重要的,本文將具體針對(duì)函數(shù)和指針的關(guān)系做詳盡的介紹
    2022-04-04

最新評(píng)論