//双指针
var removeNthFromEnd = function(head, n) {
let p1 = head, p2 = head;
for(let i = 0; i < n; i++) p1 = p1.next;
//注意这里,表示n为链表长度,不能返回null.next,所以遍历到<n
if(p1 === null) return head.next;
while(1){
p1 = p1.next;
if(p1 == null){
p2.next = p2.next.next;
return head;
}
p2 = p2.next;
}
};
19.删除链表的倒数第N个节点
最新推荐文章于 2025-12-18 10:37:20 发布
本文介绍了一个JavaScript函数`removeNthFromEnd`,它利用双指针技巧,在给定链表和删除位置n的情况下,从链表尾部开始向前移动,最终删除第n个节点并返回新的链表头部。
441

被折叠的 条评论
为什么被折叠?



