力扣每日练习 - 面试题 02.03 删除中间节点

文章目录

    • 题目描述
    • 解题代码
    • 运行结果
    • 简要解析

题目描述

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


示例:

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

解题代码

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

运行结果

力扣每日练习 - 面试题 02.03 删除中间节点_第1张图片

简要解析

题目考点:链表数据结构

其实感觉这道题最大的难点是理解题目,理解了题目再转变下思维,问题就解决了。

删除当前节点 ------->
把当前节点的值改成下一个节点的值,再将本该指向下一个节点的引用,指向下一个节点的下一个节点。(当前节点变成下一个节点,下一个节点被删除了)

你可能感兴趣的:(力扣)