296 字
1 分钟
算法之删除链表的倒数第N个节点

19.给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

**进阶:**你能尝试使用一趟扫描实现吗?

image-20210613153633327

思路:

双指针的经典应用,如果要删除倒数第n个节点,让fast移动n步,然后让fast和slow同时移动,直到fast指向链表末尾。删掉slow所指向的节点就可以了。

  • 定义fast指针和slow指针,初始值为虚拟头结点,如图:

    image-20210613155602080

  • fast首先走n + 1步 ,为什么是n+1呢,因为只有这样同时移动的时候slow才能指向删除节点的上一个节点(方便做删除操作),如图:

image-20210613155614868

  • fast和slow同时移动,之道fast指向末尾,如题:

image-20210613155634908

  • 删除slow指向的下一个节点,如图:

image-20210613155643046

解题:

/**
* Definition for singly-linked list.
* function ListNode(val, next) {
* this.val = (val===undefined ? 0 : val)
* this.next = (next===undefined ? null : next)
* }
*/
/**
* @param {ListNode} head
* @param {number} n
* @return {ListNode}
*/
var removeNthFromEnd = function (head, n) {
let preNode = new ListNode();
preNode.next = head;
let fast = preNode;
let slow = preNode;
while (n--) {
fast = fast.next;
}
while (fast.next) {
fast = fast.next;
slow = slow.next;
}
slow.next = slow.next.next;
return preNode.next;
};
算法之删除链表的倒数第N个节点
https://nollieleo.github.io/posts/算法之删除链表的倒数第n个节点/
作者
翁先森
发布于
2021-06-13
许可协议
CC BY-NC-SA 4.0