程序员面试金典 - 面试题 02.03. 删除中间节点

1. 题目

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

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

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

2. 解题

  • 只有被删除的节点,无法获取其前置节点
  • 交换要删除的节点和其下一个节点的val
  • 然后要删除的值的前一个节点就知道了
class Solution {
public:
    void deleteNode(ListNode* node) {
        swap(node->val, node->next->val);
        node->next = node->next->next;
    }
};

程序员面试金典 - 面试题 02.03. 删除中间节点_第1张图片

你可能感兴趣的:(《程序员面试金典》)