Leetcode刷题(第237题)——删除链表中的节点

x33g5p2x  于2022-03-18 转载在 其他  
字(0.7k)|赞(0)|评价(0)|浏览(331)

一、题目

请编写一个函数,用于 删除单链表中某个特定节点 。在设计函数时需要注意,你无法访问链表的头节点 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
};

五、总结

相关文章