1.知道待移除的节点的上一个节点时,只要将上一个节点的下一个节点指向待移除节点的下个节点即可:如下代码所示:
public static void deleteNode(ListNode prenode, ListNode node) {
prenode.next = node.next;
}
2.如果不知道要删除节点的上一个节点,只有待删除的节点,也就是leetcode第237题:
请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。
现有一个链表 -- head = [4,5,1,9],它可以表示为:
示例 1:
输入: head = [4,5,1,9], node = 5
输出: [4,1,9]
解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.
示例 2:
输入: head = [4,5,1,9], node = 1
输出: [4,5,9]
解释: 给定你链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9.
在这样的情况由于不知道当前待删除的节点的上一个节点,那么可以使用另一个思路:用当前节点的下一个节点的值覆盖当前的节点值,再将当前节点的next 指向下一个节点的下一个节点:
public static void deleteNode(ListNode node) {
node.val = node.next.val;
node.next = node.next.next;
}