LeetCode_数据结构入门_删除排序链表中的重复元素

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

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

示例 1:

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

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

(上述题目来源于LeetCode)

解法(一次循环):
/**
 * 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 || head.next == null){
            return head;
        }
        //定义一个指针用来标记头节点,方便后续返回
        ListNode cur = head;
        //以没有到最后一个节点为循环条件
        while(head.next != null){
            //如果值相等则跳过重复元素
            if(head.val == head.next.val){
                head.next = head.next.next;
            }else{
                head = head.next;
            }
        }
        //返回之前标记的头节点
        return cur;
    }
}
上一篇:2.5 删除链表的倒数第N个结点(线性表-链表)——【LeetCode】


下一篇:20210126 力扣刷题 合并俩个有序链表