LeetCode 每日一题83. 删除排序链表中的重复元素

83. 删除排序链表中的重复元素

存在一个按升序排列的链表,给你这个链表的头节点 head ,请你删除所有重复的元素,使每个元素 只出现一次

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

示例 1:

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

示例 2:

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

提示:

  • 链表中节点数目在范围 [0, 300]
  • -100 <= Node.val <= 100
  • 题目数据保证链表已经按升序排列

方法一:一次遍历

昨天的题 的简单版,这大概就是「深入浅出」吧。

参考代码
public ListNode deleteDuplicates(ListNode head) {
    ListNode dummy = new ListNode(101, head);
    ListNode pre = dummy;
    while (head != null) {
        if (head.val == pre.val) {
            pre.next = head.next;
        } else {
            pre = head;
        }
        head = head.next;
    }
    return dummy.next;
}

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; }
}
执行结果

LeetCode 每日一题83. 删除排序链表中的重复元素_第1张图片

你可能感兴趣的:(每日一题,链表,算法,leetcode,java)