一、题目
请编写一个函数,用于 删除单链表中某个特定节点 。在设计函数时需要注意,你无法访问链表的头节点 head
,只能直接访问 要被删除的节点 。
题目数据保证需要删除的节点 不是末尾节点 。
二、示例
输入:head = [4,5,1,9], node = 5
输出:[4,1,9]
解释:指定链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9
输入:head = [4,5,1,9], node = 1
输出:[4,5,9]
解释:指定链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9
输入:head = [1,2,3,4], node = 3
输出:[1,2,4]
三、思路
本题题目给出只可以访问当前要被删除的节点,并且题目给出需要删除的节点不是末尾节点,则就可以表名,node.next != null。此时我们可以先更改要删除节点的val,将该节点的val设置为下一个节点的val,然后将node.next 指向node.next.next即可。
四、代码展示
/**
* Definition for singly-linked list.
* function ListNode(val) {
* this.val = val;
* this.next = null;
* }
*/
/**
* @param {ListNode} node
* @return {void} Do not return anything, modify node in-place instead.
*/
var deleteNode = function(node) {
node.val = node.next.val
node.next = node.next.next
};
五、总结
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/weixin_47450807/article/details/123578819
内容来源于网络,如有侵权,请联系作者删除!