溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

C++如何移除有序鏈表中的重復(fù)項(xiàng)

發(fā)布時(shí)間:2022-03-28 13:49:41 來(lái)源:億速云 閱讀:365 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要講解了“C++如何移除有序鏈表中的重復(fù)項(xiàng)”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“C++如何移除有序鏈表中的重復(fù)項(xiàng)”吧!

移除有序鏈表中的重復(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),由于鏈表開(kāi)頭可能會(huì)有重復(fù)項(xiàng),被刪掉的話(huà)頭指針會(huì)改變,而最終卻還需要返回鏈表的頭指針。所以需要定義一個(gè)新的節(jié)點(diǎn),然后鏈上原鏈表,然后定義一個(gè)前驅(qū)指針和一個(gè)現(xiàn)指針,每當(dāng)前驅(qū)指針指向新建的節(jié)點(diǎn),現(xiàn)指針從下一個(gè)位置開(kāi)始往下遍歷,遇到相同的則繼續(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;
    }
};

同樣,我們也可以使用遞歸來(lái)做,首先判空,如果 head 為空,直接返回。然后判斷,若 head 之后的結(jié)點(diǎn)存在,且值相等,那么先進(jìn)行一個(gè) while 循環(huán),跳過(guò)后面所有值相等的結(jié)點(diǎn),到最后一個(gè)值相等的點(diǎn)停下。比如對(duì)于例子2來(lái)說(shuō),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)還是保留下來(lái)了,因?yàn)橹挡煌?,最后返?head 即可,參見(jiàn)代碼如下:

解法二:

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;
    }
};

感謝各位的閱讀,以上就是“C++如何移除有序鏈表中的重復(fù)項(xiàng)”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)C++如何移除有序鏈表中的重復(fù)項(xiàng)這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

c++
AI