存在一个按升序排列的链表,给你这个链表的头节点 head ,请你删除所有重复的元素,使每个元素 只出现一次 。
返回同样按升序排列的结果链表。
示例
示例 1:
输入:head = [1,1,2] 输出:[1,2]
示例 2:
输入:head = [1,1,2,3,3] 输出:[1,2,3]
题解
定义指针 cur ,遍历链表
判断 当前指针 cur 是否与后一位相等 cur.val === cur.next.val
如果相等 将后一位节点删除,接到 下下一个节点 cur.next = cur.next.next
如果不相等 遍历下一个节点 cur = cur.next
/*** Definition for singly-linked list.* function ListNode(val, next) {* this.val = (val===undefined ? 0 : val)* this.next = (next===undefined ? null : next)* }*//*** @param {ListNode} head* @return {ListNode}*/var deleteDuplicates = function(head) {let cur = headwhile (cur && cur.next) {if (cur.val === cur.next.val) {cur.next = cur.next.next} else {cur = cur.next}}return head};
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/remove-duplicates-from-sorted-list
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
