C++實現LeetCode(82.移除有序鏈表中的重復項之二)
[LeetCode] 82. Remove Duplicates from Sorted List II 移除有序鏈表中的重復項之二
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 不同的地方是這裡要刪掉所有的重復項,由於鏈表開頭可能會有重復項,被刪掉的話頭指針會改變,而最終卻還需要返回鏈表的頭指針。所以需要定義一個新的節點,然後鏈上原鏈表,然後定義一個前驅指針和一個現指針,每當前驅指針指向新建的節點,現指針從下一個位置開始往下遍歷,遇到相同的則繼續往下,直到遇到不同項時,把前驅指針的next指向下面那個不同的元素。如果現指針遍歷的第一個元素就不相同,則把前驅指針向下移一位。代碼如下:
解法一:
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 之後的結點存在,且值相等,那麼先進行一個 while 循環,跳過後面所有值相等的結點,到最後一個值相等的點停下。比如對於例子2來說,head 停在第三個結點1處,然後對後面一個結點調用遞歸函數,即結點2,這樣做的好處是,返回的值就完全把所有的結點1都刪掉瞭。若 head 之後的結點值不同,那麼還是對 head 之後的結點調用遞歸函數,將返回值連到 head 的後面,這樣 head 結點還是保留下來瞭,因為值不同嘛,最後返回 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; } };
到此這篇關於C++實現LeetCode(82.移除有序鏈表中的重復項之二)的文章就介紹到這瞭,更多相關C++實現移除有序鏈表中的重復項之二內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- C++實現LeetCode(148.鏈表排序)
- C++實現LeetCode(21.混合插入有序鏈表)
- C++實現LeetCode(147.鏈表插入排序)
- C++實現LeetCode(86.劃分鏈表)
- C++實現LeetCode(25.每k個一組翻轉鏈表)