题目大意:
删除链表中的节点
请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。
现有一个链表 — 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.
本网站文章均为原创内容,并可随意转载,但请标明本文链接如有任何疑问可在文章底部留言。为了防止恶意评论,本博客现已开启留言审核功能。但是博主会在后台第一时间看到您的留言,并会在第一时间对您的留言进行回复!欢迎交流!
本文链接: http://leetcode.jp/leetcode-237-delete-node-in-a-linked-list-解题思路分析-2/