存在一个按升序排列的链表,给你这个链表的头节点 head ,请你删除链表中所有存在数字重复情况的节点,只保留原始链表中 没有重复出现 的数字。

返回同样按升序排列的结果链表。

 

示例 1:

输入:head = [1,2,3,3,4,4,5]
输出:[1,2,5]

示例 2:

输入:head = [1,1,1,2,3]
输出:[2,3]

 

提示:

  • 链表中节点数目在范围 [0, 300]
  • -100 <= Node.val <= 100
  • 题目数据保证链表已经按升序排列
Related Topics
  • 链表
  • \n
  • 👍 606
  • 👎 0
  • 1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    //存在一个按升序排列的链表,给你这个链表的头节点 head ,请你删除链表中所有存在数字重复情况的节点,只保留原始链表中 没有重复出现 的数字。 
    //
    // 返回同样按升序排列的结果链表。
    //
    //
    //
    // 示例 1:
    //
    //
    //输入:head = [1,2,3,3,4,4,5]
    //输出:[1,2,5]
    //
    //
    // 示例 2:
    //
    //
    //输入:head = [1,1,1,2,3]
    //输出:[2,3]
    //
    //
    //
    //
    // 提示:
    //
    //
    // 链表中节点数目在范围 [0, 300] 内
    // -100 <= Node.val <= 100
    // 题目数据保证链表已经按升序排列
    //
    // Related Topics 链表
    // 👍 606 👎 0


    //leetcode submit region begin(Prohibit modification and deletion)
    /**
    * Definition for singly-linked list.
    * public class ListNode {
    * int val;
    * ListNode next;
    * ListNode() {}
    * ListNode(int val) { this.val = val; }
    * ListNode(int val, ListNode next) { this.val = val; this.next = next; }
    * }
    */
    class Solution {
    public ListNode deleteDuplicates(ListNode head) {
    if (head == null) {
    return head;
    }
    ListNode dummy = new ListNode(0, head);
    //考虑头节点可能被删除,所以需要构造一个哑结点
    ListNode curr = dummy;
    while (curr.next != null && curr.next.next != null) {
    if (curr.next.val == curr.next.next.val) {
    int x = curr.next.val;
    while (curr.next != null && curr.next.val == x) {
    curr.next = curr.next.next;
    }
    } else {
    curr = curr.next;
    }
    }
    return dummy.next;
    }
    }
    // leetcode submit region end(Prohibit modification and deletion)