【LeetCode】【简单】 删除中间节点

痞子三分冷 提交于 2020-02-17 09:14:03

题目:

实现一种算法,删除单向链表中间的某个节点(除了第一个和最后一个节点,不一定是中间节点),假定你只能访问该节点。

 

示例:

输入:单向链表a->b->c->d->e->f中的节点c
结果:不返回任何数据,但该链表变为a->b->d->e->f

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/delete-middle-node-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

-------------------------------------------------------------------------------------------------------------------------

第一次:

class Solution {

public:

    void deleteNode(ListNode* node) {

        node->val = node->next->val;

        node->next = node->next->next;

    }

};

总结:

1. 直接把要删除节点的后继节点赋值给该节点,链表就会变成如下所示:

要删除第2个节点 则将第3个节点的值和指针赋值给第2个节点 此时第2个节点指针指向 第4个节点,但这时候只是断开了第2个节点和第3个节点的连接,第3个节点依然存在,且可以通过第3个节点直接访问第4个节点。且如果第三个节点是动态分配的,需要释放空间。需要将第3个节点的数据清空,释放资源。

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!