1. 程式人生 > >LeetCode83 刪除排序連結串列中的重複元素

LeetCode83 刪除排序連結串列中的重複元素

給定一個排序連結串列,刪除所有重複的元素,使得每個元素只出現一次。

示例 1:

輸入: 1->1->2
輸出: 1->2

示例 2:

輸入: 1->1->2->3->3
輸出: 1->2->3




/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 
*/ /* 演算法思想: 定義個指標指向該連結串列的第一個元素,然後第一個元素和第二個元素比較,如果重複了,則刪掉第二個元素,如果不重複,指標指向第二個元素。這樣遍歷完整個連結串列,則剩下的元素沒有重複項。 */ //演算法實現: class Solution { public: ListNode *deleteDuplicates(ListNode *head) { if (!head || !head->next) return head; ListNode *start = head;
while (start && start->next) { if (start->val == start->next->val) { ListNode *tmp = start->next; start->next = start->next->next; delete tmp; } else start = start->next; }
return head; } };