C++實(shí)現(xiàn)LeetCode(82.移除有序鏈表中的重復(fù)項(xiàng)之二)
[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語(yǔ)言實(shí)現(xiàn)掃雷小游戲(擴(kuò)展版)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)擴(kuò)展版的掃雷小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
Qt Design Studio創(chuàng)建工程的實(shí)現(xiàn)方法
Qt Design Studio它允許設(shè)計(jì)人員和開發(fā)人員使用通用的設(shè)計(jì)、開發(fā)、分析和調(diào)試工具在不同的開發(fā)平臺(tái)上共享一個(gè)項(xiàng)目,本文主要介紹了Qt Design Studio創(chuàng)建工程的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的可以了解一下2022-05-05
Unity3D實(shí)現(xiàn)經(jīng)典小游戲Pacman
這篇文章主要介紹了基于Unity3D制作一做個(gè)經(jīng)典小游戲Pacman,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Unity3D有一定的幫助,感興趣的小伙伴可以了解一下2021-12-12
動(dòng)態(tài)數(shù)組C++實(shí)現(xiàn)方法(分享)
下面小編就為大家?guī)硪黄獎(jiǎng)討B(tài)數(shù)組C++實(shí)現(xiàn)方法(分享)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05

