力扣82.删除排序链表中的重复元素Ⅱ

思路:递归,如果当前结点与下一个结点值相等,那么就返回下一个值不相等的结点,如果当前结点与下一结点值不相等,那么就判断下一结点与下下个结点值是否相等

力扣82.删除排序链表中的重复元素Ⅱ_第1张图片

代码:
 

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* deleteDuplicates(ListNode* head) {
        if(head == NULL || head->next == NULL) return head;
        if(head->val == head->next->val) {
            int val = head->val;
            while(head && head->val == val){
                head = head->next;
            }
            return deleteDuplicates(head);
        }
        head->next = deleteDuplicates(head->next);
        return head;
    }
};

你可能感兴趣的:(力扣刷题笔记,leetcode,链表,算法)