日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[leetcode笔记] Remove Duplicates from Sorted List II

發布時間:2025/7/25 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [leetcode笔记] 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.

For example,
Given?1->2->3->3->4->4->5, return?1->2->5.
Given?1->1->1->2->3, return?2->3.

?

解題筆記:

折騰了好多次,這次先寫好很多測試用例,剛開始總是不過,總有情況未處理好,修改了多次后終于寫成:

1 class Solution { 2 public: 3 ListNode *deleteDuplicates(ListNode *head) { 4 if (head==NULL || head->next==NULL) 5 return head; 6 7 ListNode *pDummyHead = new ListNode(0); 8 pDummyHead->next = head; 9 10 ListNode *pNewHead = head; 11 ListNode *p = head; 12 ListNode *pLast = pDummyHead; 13 14 bool bFoundHead = false; 15 while (p->next) 16 { 17 int nLastValue = p->val; 18 ListNode *pSub = p->next; 19 if (p->val != pSub->val) 20 { 21 if (bFoundHead==false) 22 { 23 bFoundHead=true; 24 pNewHead = p; 25 } 26 pLast = p; 27 p = p->next; 28 continue; 29 } 30 while (pSub && (pSub->val == nLastValue)) 31 { 32 ListNode *pToDelete = pSub; 33 pSub = pSub->next; 34 delete pToDelete; 35 } 36 ListNode *pToDelete = p; 37 p = pSub; 38 delete pToDelete; 39 pLast->next = pSub; 40 if (p==NULL) 41 break; 42 } 43 if (bFoundHead==false) 44 { 45 pNewHead = p; 46 } 47 delete pDummyHead; 48 return pNewHead; 49 } 50 };

?

提交OJ,Accepted!

?

轉載于:https://www.cnblogs.com/lequ/p/3885935.html

總結

以上是生活随笔為你收集整理的[leetcode笔记] Remove Duplicates from Sorted List II的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。