LeetCode-Day41 (C#) 203. 移除链表元素

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点

示例 1:

image

输入:head = [1,2,6,3,4,5,6], val = 6
输出:[1,2,3,4,5]

示例 2:

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

示例 3:

输入:head = [7,7,7,7], val = 7
输出:[]

提示:

  • 列表中的节点在范围 [0, 104]
  • 1 <= Node.val <= 50
  • 0 <= k <= 50

方法:哨兵节点
如果删除的节点是中间的节点,则问题似乎非常简单:

选择要删除节点的前一个结点 prev。
将 prev 的 next 设置为要删除结点的 next。

当要删除的一个或多个节点位于链表的头部时,事情会变得复杂。

可以通过哨兵节点去解决它,哨兵节点广泛应用于树和链表中,如伪头、伪尾、标记等,它们是纯功能的,通常不保存任何数据,其主要目的是使链表标准化,如使链表永不为空、永不无头、简化插入和删除。

在这里哨兵节点将被用于伪头。

算法:

初始化哨兵节点为 ListNode(0) 且设置 sentinel.next = head。
初始化两个指针 curr 和 prev 指向当前节点和前继节点。
当 curr != nullptr:
比较当前节点和要删除的节点:
若当前节点就是要删除的节点:则 prev.next = curr.next。
否则设 prve = curr。
遍历下一个元素:curr = curr.next。
返回 sentinel.next。

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     public int val;
 *     public ListNode next;
 *     public ListNode(int val=0, ListNode next=null) {
 *         this.val = val;
 *         this.next = next;
 *     }
 * }
 */
public class Solution {
    public ListNode RemoveElements(ListNode head, int val) {
        if(head == null) return null;
        ListNode cur = head, use = new ListNode(0, head);
        head = use;
        while(cur != null){
            if(cur.val == val) head.next = cur.next;
            else head = cur;
            cur = cur.next;
        }
        return use.next;
    }
}

你可能感兴趣的:(LeetCode-Day41 (C#) 203. 移除链表元素)