C++中從已排序列表中刪除重複項


假設我們有一個包含一些元素的列表。我們必須刪除所有出現不止一次的元素。因此,列表中只保留不同的元素。如果列表類似於[1,1,1,2,2,3,5,6,6,7,8],則輸出將為[3,5,7,8],所有其他元素都出現不止一次。

讓我們看看步驟 -

  • 建立一個值為-1的虛擬節點,prev := NULL,dummyPtr := dummy
  • 當head不為空時
    • 如果head的下一個節點存在,或者head的值與下一個節點的值不同,則
      • dummyPtr的下一個節點 := head
      • temp := head的下一個節點,並將head的下一個節點設為空
      • head := temp
      • dummyPtr := dummyPtr的下一個節點
    • 否則
      • prev := head,head := head的下一個節點
      • 當head不為空且head的值等於prev的值時
        • prev := head,head := head的下一個節點
  • 返回dummy的下一個節點

讓我們看看下面的實現,以便更好地理解 -

示例

 線上演示

#include <bits/stdc++.h>
using namespace std;
class ListNode{
   public:
      int val;
      ListNode *next;
      ListNode(int data){
         val = data;
         next = NULL;
      }
   };
   ListNode *make_list(vector<int> v){
      ListNode *head = new ListNode(v[0]);
      for(int i = 1; i<v.size(); i++){
         ListNode *ptr = head;
         while(ptr->next != NULL){
            ptr = ptr->next;
         }
         ptr->next = new ListNode(v[i]);
      }
      return head;
   }
   void print_list(ListNode *head){
      ListNode *ptr = head;
      cout << "[";
      while(ptr){
      cout << ptr->val << ", ";
      ptr = ptr->next;
   }
   cout << "]" << endl;
}
class Solution {
   public:
   ListNode* deleteDuplicates(ListNode* head) {
      ListNode* dummy = new ListNode(-1);
      ListNode* prev = NULL;
      ListNode* dummyPtr = dummy;
      ListNode* nextNode;
      while(head){
         if(!head->next || head->val != head->next->val){
            dummyPtr->next = head;
            ListNode* temp = head->next;
            head->next = NULL;
            head = temp;
            dummyPtr = dummyPtr->next;
         } else {
            prev = head;
            head = head->next;
            while(head && head->val == prev->val){
               prev = head;
               head = head->next;
            }
         }
      }
   return dummy->next;
   }
};
main(){
   Solution ob;
   vector<int> v = {1,1,1,2,2,3,5,6,6,7,8};
   ListNode *head = make_list(v);
   print_list(ob.deleteDuplicates(head));
}

輸入

[1,1,1,2,2,3,5,6,6,7,8]

輸出

[3, 5, 7, 8, ]

更新於:2020年5月4日

241 次瀏覽

啟動您的職業生涯

透過完成課程獲得認證

開始學習
廣告
© . All rights reserved.