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

解题思路分析:

我要先给这道题来个差评(读了几遍居然没明白题目要求)。

实际上题目要求我们实现一个算法,在不知道链表根节点的情况下,通过某个已知节点来从链表中删除该节点。这道题实现上的难度并不大,我们只需要将当前节点的值设定为下一个节点的值,并且将该节点的下一个节点,指向下一个节点的下一个节点即可。

这里你可能会有一个疑问,如将当前节点直接设置为下一个节点如何(node = node.next)?这就涉及到指针和变量的问题了。以下引用其他朋友给出的解释:node = node.next只是把node指向了node.next指向的对象,改变的只是指针node的指向,不影响实际链表的结构。例如有链表[4,5,1,9],node = 5。node=node.next。只是把node指向了1这个节点,但是4这个节点的next依旧指向了5,所以5这个要求被删除的节点并没有被覆盖或者删除。实际上node 是一个变量名,代表对某个 ListNode 对象的【引用】,你可以把它想象成一个游标或者标签。node = node.next 只是修改了变量名的指向,相当于把标签从 node 代表的初始对象上撕下,然后贴到 node.next 指向的对象上,这对链表结构不会产生任何影响,因此最终不会产生任何效果。这个疑问是对引用类型的常见误解,引用类型的赋值操作不同于基本类型:基本类型赋值时通常会拷贝内存数据,但引用类型赋值只是简单地改变引用的指向,不涉及内存操作。

实现代码:

public void deleteNode(ListNode node) {
    node.val=node.next.val;
    node.next=node.next.next;
}

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

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

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

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

发表评论

您的电子邮箱地址不会被公开。