X

LEETCODE 237. Delete Node in a Linked List 解题思路分析

题目大意:

删除链表中的节点

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

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

说明:

  • 链表至少包含两个节点。
  • 链表中所有节点的值都是唯一的。
  • 给定的节点为非末尾节点并且一定是链表中的一个有效节点。
  • 不要从你的函数中返回任何结果。

如果想查看本题目是哪家公司的面试题,请参考以下免费链接: https://leetcode.jp/problemdetail.php?id=237

解题思路分析:

本题如果能知道被删除节点的前一节点,我们只需要将前一节点的下一节点设置成为删除节点的下一节点即可。但题目只给出了要删除的节点,所以该节点之前的所有节点我们都无法取得。这样也不难,我们只要将被删除节点的内容更改为其下一节点即可。

实现代码:

public void deleteNode(ListNode node) {
    // 删除节点的下一节点
    ListNode next = node.next;
    // 将被删除节点的值更改为下一节点的值
    node.val=next.val;
    // 将被删除节点的下一节点更改为下一节点的下一节点
    node.next = next.next;
}

本题解法执行时间为0ms。

Runtime: 0 ms, faster than 100.00% of Java online submissions for Delete Node in a Linked List.

Memory Usage: 36.8 MB, less than 100.00% of Java online submissions for Delete Node in a Linked List.

本网站文章均为原创内容,并可随意转载,但请标明本文链接
如有任何疑问可在文章底部留言。为了防止恶意评论,本博客现已开启留言审核功能。但是博主会在后台第一时间看到您的留言,并会在第一时间对您的留言进行回复!欢迎交流!
本文链接: https://leetcode.jp/leetcode-237-delete-node-in-a-linked-list-解题思路分析/
Categories: leetcode
kwantong: