给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次。

示例 1:

输入: 1->1->2
输出: 1->2

示例 2:

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

思路

设置两个指着,p 和 q,q 始终在 p 下一位,当 q 不为空时循环,若 q、p所指的值相等,说明重复元素,删除 q 这个节点,若不相等,p 和 q 都向后移一位。

/** * Definition for singly-linked list. * function ListNode(val) { * this.val = val; * this.next = null; * } */
/** * @param {ListNode} head * @return {ListNode} */
var deleteDuplicates = function(head) {
  if (!head || !head.next) return head
  let p = head
  let q = p.next
  while (q) {
    if (p.val === q.val) {
      q = q.next
      p.next = q
    } else {
      p = q
      q = q.next
    }
  }
  return head
};