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

题目描述:

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

示例:

示例 1:

LeetCode——删除排序链表中的重复元素_第1张图片

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

示例 2:

LeetCode——删除排序链表中的重复元素_第2张图片

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

解答:

/**
 * 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;
        }
        head.next=deleteDuplicates(head.next);
        if(head.val==head.next.val)
        {
            head=head.next;
        }
        return head;
    }
}
笔记:

先进行判空操作,若头节点和头节点下一个节点为空,直接返回。
若不为空,进行一递归。
进行前一节点和下一节点值val的判断,相同,改变指针位置,指向下一节点,以此类推,最后返回head

你可能感兴趣的:(LeetCode,链表,leetcode,数据结构)