18劍指OFFER之刪除鏈表中重復(fù)的節(jié)點

參考資料:

[1]好的參考資料1:https://blog.csdn.net/qq_24486393/article/details/51868590
[2]好的參考資料2:https://www.cnblogs.com/linkstar/p/5995066.html

關(guān)鍵詞:

兩個指針包个、如何刪除重復(fù)的節(jié)點俊戳、如何防止鏈表的第一個節(jié)點被刪除

類似題目:

leetcode
刪除鏈表的節(jié)點
remove-duplicates-from-sorted-list-ii
remove-duplicates-from-sorted-list

思路:

remove-duplicates-from-sorted-list-ii
如果當(dāng)前節(jié)點和當(dāng)前節(jié)點的下一個節(jié)點的值相同的話威蕉,那么找到和當(dāng)前節(jié)點的值不相同的第一個節(jié)點沛慢,將前一個節(jié)點指向當(dāng)前節(jié)點。
如果當(dāng)前節(jié)點和當(dāng)前節(jié)點的下一個節(jié)點的值不同的話料扰,那么前一個節(jié)點為當(dāng)前節(jié)點,當(dāng)前節(jié)點為當(dāng)前節(jié)點的下一個節(jié)點。

全部刪除和只留一個就是一行代碼的區(qū)別E祷觥!<缆筷笨!

自己的解答:
刪除鏈表的節(jié)點

參考資料:劍指OFFER課本面試題18:
考慮各種情況:

void DeleteListNode(ListNode* pHead, ListNode* pDeleteNode)
{
    //1.如果鏈表就一個節(jié)點的話,或者沒有節(jié)點
    if (pHead == nullptr || pHead->m_pNext == nullptr)
    {
        pHead = nullptr;
        return;
    }

    ListNode* pNode = pHead;
    //如果刪除的節(jié)點為鏈表的尾節(jié)點,那么只能從頭到尾進行遍歷
    if (pDeleteNode->m_pNext == nullptr)


    {
        while (pNode->m_pNext != pDeleteNode)
        {
            pNode = pNode->m_pNext;
        }
        pNode->m_pNext = nullptr;
        return;
    }

    //如果刪除的節(jié)點位于前面的節(jié)點
    pDeleteNode->m_nKey = pDeleteNode->m_pNext->m_nKey;
    pDeleteNode->m_pNext = pDeleteNode->m_pNext->m_pNext;

}

Leetecode上的解答(這里只考慮一種情況):

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    void deleteNode(ListNode* node) {
     
        node->val = node->next->val;
        node->next = node->next->next;
        return;
        
        
        
    }
};
remove-duplicates-from-sorted-list-ii

改進版:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode *deleteDuplicates(ListNode *head) {
        
        //如果節(jié)點為空或者只有一個節(jié)點的話龟劲,那么返回
        if (head == nullptr || head->next == nullptr)
            return head;

        //定義一個節(jié)點胃夏,防止投節(jié)點被刪除
        ListNode* pFirst = new ListNode(0);
        pFirst->next = head;

        //定義前一個節(jié)點和當(dāng)前節(jié)點
        ListNode* pPrev = pFirst;
        ListNode* pNode = head;


        while (pNode != nullptr && pNode->next != nullptr)
        {
            //1.如果當(dāng)前節(jié)點的值和當(dāng)前節(jié)點的下一個節(jié)點相同的話,那么找一個不相同的節(jié)點,其他是否為空的都是為了程序的正常運行
            if (pNode->val == pNode->next->val)
            {
                while(pNode!= nullptr&& pNode->next!= nullptr && pNode->val == pNode->next->val)//特別注意這個的執(zhí)行順序啊
                    pNode = pNode->next;
                pPrev->next = pNode->next;
                pNode = pNode->next;//要注意當(dāng)前節(jié)點
            }
            else
            {
                pPrev = pNode;
                pNode = pNode->next;
                
            }
            
        }
        return pFirst->next;
    
    }
};
remove-duplicates-from-sorted-list-i

改進版:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode *deleteDuplicates(ListNode *head) {
        
        //如果節(jié)點為空或者只有一個節(jié)點的話昌跌,那么返回
        if (head == nullptr || head->next == nullptr)
            return head;

        //定義一個節(jié)點仰禀,防止投節(jié)點被刪除
        ListNode* pFirst = new ListNode(0);
        pFirst->next = head;

        //定義前一個節(jié)點和當(dāng)前節(jié)點
        ListNode* pPrev = pFirst;
        ListNode* pNode = head;


        while (pNode != nullptr && pNode->next != nullptr)
        {
            //1.如果當(dāng)前節(jié)點的值和當(dāng)前節(jié)點的下一個節(jié)點相同的話,那么找一個不相同的節(jié)點,其他是否為空的都是為了程序的正常運行
            if (pNode->val == pNode->next->val)
            {
                while(pNode!= nullptr&& pNode->next!= nullptr && pNode->val == pNode->next->val)//特別注意這個的執(zhí)行順序啊
                    pNode = pNode->next;
                pPrev->next = pNode;
            }
            else
            {
                pPrev = pNode;
                pNode = pNode->next;
                
            }
            
        }
        return pFirst->next;
            
    }
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蚕愤,一起剝皮案震驚了整個濱河市答恶,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌萍诱,老刑警劉巖悬嗓,帶你破解...
    沈念sama閱讀 219,539評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異裕坊,居然都是意外死亡包竹,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評論 3 396
  • 文/潘曉璐 我一進店門碍庵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來映企,“玉大人,你說我怎么就攤上這事静浴⊙呙ィ” “怎么了?”我有些...
    開封第一講書人閱讀 165,871評論 0 356
  • 文/不壞的土叔 我叫張陵苹享,是天一觀的道長双絮。 經(jīng)常有香客問我,道長得问,這世上最難降的妖魔是什么囤攀? 我笑而不...
    開封第一講書人閱讀 58,963評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮宫纬,結(jié)果婚禮上焚挠,老公的妹妹穿的比我還像新娘。我一直安慰自己漓骚,他們只是感情好蝌衔,可當(dāng)我...
    茶點故事閱讀 67,984評論 6 393
  • 文/花漫 我一把揭開白布榛泛。 她就那樣靜靜地躺著,像睡著了一般噩斟。 火紅的嫁衣襯著肌膚如雪曹锨。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,763評論 1 307
  • 那天剃允,我揣著相機與錄音沛简,去河邊找鬼。 笑死斥废,一個胖子當(dāng)著我的面吹牛椒楣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播营袜,決...
    沈念sama閱讀 40,468評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼撒顿,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了荚板?” 一聲冷哼從身側(cè)響起凤壁,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎跪另,沒想到半個月后辑奈,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體刺下,經(jīng)...
    沈念sama閱讀 45,850評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡咪笑,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,002評論 3 338
  • 正文 我和宋清朗相戀三年零渐,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片嘲驾。...
    茶點故事閱讀 40,144評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡淌哟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出辽故,到底是詐尸還是另有隱情徒仓,我是刑警寧澤,帶...
    沈念sama閱讀 35,823評論 5 346
  • 正文 年R本政府宣布誊垢,位于F島的核電站掉弛,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏喂走。R本人自食惡果不足惜殃饿,卻給世界環(huán)境...
    茶點故事閱讀 41,483評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望芋肠。 院中可真熱鬧乎芳,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至携取,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間帮孔,已是汗流浹背雷滋。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留文兢,地道東北人晤斩。 一個月前我還...
    沈念sama閱讀 48,415評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像姆坚,于是被迫代替她去往敵國和親澳泵。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,092評論 2 355

推薦閱讀更多精彩內(nèi)容