删除链表中的节点

204 阅读1分钟

请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。

现有一个链表 – 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.

来源:力扣(LeetCode)
链接:leetcode-cn.com/problems/de…

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    void deleteNode(ListNode* node) {
        node->val=node->next->val;
        node->next=node->next->next;
    }
};

为什么不能直接node=node->next?
实际上在一般情况下删除1链表中的一个节点,如已知p->next=q;q->next=r;很显然p的下一个结点是q,q的下一个结点是r,若要删除q,需要做的是p->next=r;这样才是正确的.
为什么在这道题里不能node=node->next?

从链表里删除一个节点 node 的最常见方法是修改之前节点的 next 指针,使其指向之后的节点。
在这道题中,我们无法访问我们想要删除的节点之前的节点,我们始终不能修改该节点的 next 指针。相反,我们必须将想要删除的节点的值替换为它后面节点中的值,然后删除它之后的节点。
所以这道题并没有真正做到删除,它在覆盖后没有释放,这在c++中是错误的