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

C++實(shí)現(xiàn)LeetCode(82.移除有序鏈表中的重復(fù)項(xiàng)之二)

 更新時(shí)間:2021年07月17日 15:24:55   作者:Grandyang  
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(82.移除有序鏈表中的重復(fù)項(xiàng)之二),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

[LeetCode] 82. Remove Duplicates from Sorted List II 移除有序鏈表中的重復(fù)項(xiàng)之二

Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numbers from the original list.

Example 1:

Input: 1->2->3->3->4->4->5
Output: 1->2->5

Example 2:

Input: 1->1->1->2->3
Output: 2->3

和之前那道 Remove Duplicates from Sorted List 不同的地方是這里要?jiǎng)h掉所有的重復(fù)項(xiàng),由于鏈表開頭可能會(huì)有重復(fù)項(xiàng),被刪掉的話頭指針會(huì)改變,而最終卻還需要返回鏈表的頭指針。所以需要定義一個(gè)新的節(jié)點(diǎn),然后鏈上原鏈表,然后定義一個(gè)前驅(qū)指針和一個(gè)現(xiàn)指針,每當(dāng)前驅(qū)指針指向新建的節(jié)點(diǎn),現(xiàn)指針從下一個(gè)位置開始往下遍歷,遇到相同的則繼續(xù)往下,直到遇到不同項(xiàng)時(shí),把前驅(qū)指針的next指向下面那個(gè)不同的元素。如果現(xiàn)指針遍歷的第一個(gè)元素就不相同,則把前驅(qū)指針向下移一位。代碼如下:

解法一:

class Solution {
public:
    ListNode* deleteDuplicates(ListNode* head) {
        ListNode *cur = head;
        while (cur && cur->next) {
            if (cur->val == cur->next->val) {
                cur->next = cur->next->next;
            } else {
                cur = cur->next;
            }
        }
        return head;
    }
};

同樣,我們也可以使用遞歸來做,首先判空,如果 head 為空,直接返回。然后判斷,若 head 之后的結(jié)點(diǎn)存在,且值相等,那么先進(jìn)行一個(gè) while 循環(huán),跳過后面所有值相等的結(jié)點(diǎn),到最后一個(gè)值相等的點(diǎn)停下。比如對(duì)于例子2來說,head 停在第三個(gè)結(jié)點(diǎn)1處,然后對(duì)后面一個(gè)結(jié)點(diǎn)調(diào)用遞歸函數(shù),即結(jié)點(diǎn)2,這樣做的好處是,返回的值就完全把所有的結(jié)點(diǎn)1都刪掉了。若 head 之后的結(jié)點(diǎn)值不同,那么還是對(duì) head 之后的結(jié)點(diǎn)調(diào)用遞歸函數(shù),將返回值連到 head 的后面,這樣 head 結(jié)點(diǎn)還是保留下來了,因?yàn)橹挡煌?,最后返?head 即可,參見代碼如下:

解法二:

class Solution {
public:
    ListNode* deleteDuplicates(ListNode* head) {
        if (!head || !head->next) return head;
        head->next = deleteDuplicates(head->next);
        return (head->val == head->next->val) ? head->next : head;
    }
};

到此這篇關(guān)于C++實(shí)現(xiàn)LeetCode(82.移除有序鏈表中的重復(fù)項(xiàng)之二)的文章就介紹到這了,更多相關(guān)C++實(shí)現(xiàn)移除有序鏈表中的重復(fù)項(xiàng)之二內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 基于C++實(shí)現(xiàn)擲雙骰游戲的示例代碼

    基于C++實(shí)現(xiàn)擲雙骰游戲的示例代碼

    在最流行的博彩游戲中有一種名為“擲雙骰”(craps)的骰子游戲,這種游戲在世界各地的娛樂場所和大街小巷非常受歡迎。本文將用C++語言實(shí)現(xiàn)這一游戲,需要的可以參考一下
    2022-03-03
  • C語言文件操作詳情(二)

    C語言文件操作詳情(二)

    這篇文章主要介紹了C語言文件操作詳情,文章基于上一篇文章的內(nèi)容繼續(xù)展開C語言文件操作的相關(guān)詳情,需要的小伙伴可以參考一下
    2022-04-04
  • C語言 不使用strcat函數(shù)實(shí)現(xiàn)連接兩個(gè)字符串功能代碼

    C語言 不使用strcat函數(shù)實(shí)現(xiàn)連接兩個(gè)字符串功能代碼

    今天小編就為大家分享一篇C語言 不使用strcat函數(shù)實(shí)現(xiàn)連接兩個(gè)字符串功能代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • C++ 搬水果貪心算法實(shí)現(xiàn)代碼

    C++ 搬水果貪心算法實(shí)現(xiàn)代碼

    這篇文章主要介紹了C++ 搬水果貪心算法實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • Java C++算法題解leetcode1592重新排列單詞間的空格

    Java C++算法題解leetcode1592重新排列單詞間的空格

    這篇文章主要為大家介紹了Java C++算法題解leetcode1592重新排列單詞間的空格示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • C++順序表的基本操作(使用模版類)

    C++順序表的基本操作(使用模版類)

    這篇文章主要為大家詳細(xì)介紹了C++順序表的基本操作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • 最新VScode C/C++ 環(huán)境配置的詳細(xì)教程

    最新VScode C/C++ 環(huán)境配置的詳細(xì)教程

    這篇文章主要介紹了最新VScode C/C++ 環(huán)境配置的詳細(xì)教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • 基于C語言實(shí)現(xiàn)貪吃蛇小游戲

    基于C語言實(shí)現(xiàn)貪吃蛇小游戲

    這篇文章主要為大家詳細(xì)介紹了基于C語言實(shí)現(xiàn)貪吃蛇小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C++中Cbitmap,HBitmap,Bitmap區(qū)別及聯(lián)系

    C++中Cbitmap,HBitmap,Bitmap區(qū)別及聯(lián)系

    這篇文章主要介紹了C++中Cbitmap,HBitmap,Bitmap區(qū)別及聯(lián)系的相關(guān)資料,需要的朋友可以參考下
    2015-06-06
  • C語言實(shí)現(xiàn)簡單通訊錄

    C語言實(shí)現(xiàn)簡單通訊錄

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡易通訊錄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05

最新評(píng)論