1 題目描述
給定一個排序鏈表,刪除所有重複的元素,使得每個元素只出現一次。
示例 1:
輸入: 1->1->2
輸出: 1->2
示例 2:
輸入: 1->1->2->3->3
輸出: 1->2->3
來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/remove-duplicates-from-sorted-list
著作權歸領釦網絡所有。商業轉載請聯繫官方授權,非商業轉載請註明出處。
2 解題思路
由於輸入的列表已排序,因此我們可以通過將結點的值與它之後的結點進行比較來確定它是否爲重複結點。如果它是重複的,我們更改當前結點的 next 指針,以便它跳過下一個結點並直接指向下一個結點之後的結點。
複雜度分析
時間複雜度:O(n),因爲列表中的每個結點都檢查一次以確定它是否重複,所以總運行時間爲 O(n),其中 n 是列表中的結點數。
空間複雜度:O(1),沒有使用額外的空間。
3 解決代碼
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution {
public ListNode deleteDuplicates(ListNode head) {
ListNode current = head;
while(current != null && current.next != null){
if(current.val == current.next.val){
current.next = current.next.next;
}else{
current = current.next;
}
}
return head;
}
}