C++實現(xiàn)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 不同的地方是這里要刪掉所有的重復項,由于鏈表開頭可能會有重復項,被刪掉的話頭指針會改變,而最終卻還需要返回鏈表的頭指針。所以需要定義一個新的節(jié)點,然后鏈上原鏈表,然后定義一個前驅(qū)指針和一個現(xiàn)指針,每當前驅(qū)指針指向新建的節(jié)點,現(xiàn)指針從下一個位置開始往下遍歷,遇到相同的則繼續(xù)往下,直到遇到不同項時,把前驅(qū)指針的next指向下面那個不同的元素。如果現(xiàn)指針遍歷的第一個元素就不相同,則把前驅(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é)點存在,且值相等,那么先進行一個 while 循環(huán),跳過后面所有值相等的結(jié)點,到最后一個值相等的點停下。比如對于例子2來說,head 停在第三個結(jié)點1處,然后對后面一個結(jié)點調(diào)用遞歸函數(shù),即結(jié)點2,這樣做的好處是,返回的值就完全把所有的結(jié)點1都刪掉了。若 head 之后的結(jié)點值不同,那么還是對 head 之后的結(jié)點調(diào)用遞歸函數(shù),將返回值連到 head 的后面,這樣 head 結(jié)點還是保留下來了,因為值不同嘛,最后返回 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++實現(xiàn)LeetCode(82.移除有序鏈表中的重復項之二)的文章就介紹到這了,更多相關C++實現(xiàn)移除有序鏈表中的重復項之二內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
C語言 不使用strcat函數(shù)實現(xiàn)連接兩個字符串功能代碼
今天小編就為大家分享一篇C語言 不使用strcat函數(shù)實現(xiàn)連接兩個字符串功能代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12
Java C++算法題解leetcode1592重新排列單詞間的空格
這篇文章主要為大家介紹了Java C++算法題解leetcode1592重新排列單詞間的空格示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09
最新VScode C/C++ 環(huán)境配置的詳細教程
這篇文章主要介紹了最新VScode C/C++ 環(huán)境配置的詳細教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11
C++中Cbitmap,HBitmap,Bitmap區(qū)別及聯(lián)系
這篇文章主要介紹了C++中Cbitmap,HBitmap,Bitmap區(qū)別及聯(lián)系的相關資料,需要的朋友可以參考下2015-06-06

