算法-删除链表的倒数第 N 个结点

Posted natsu-cc

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法-删除链表的倒数第 N 个结点相关的知识,希望对你有一定的参考价值。

题目:

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

示例1:

输入:head = [1,2,3,4,5], n = 2
输出:[1,2,3,5]

示例2:

输入:head = [1], n = 1
输出:[]

示例3:

输入:head = [1,2], n = 1
输出:[1]

提示:

链表中结点的数目为 sz
1 <= sz <= 30
0 <= Node.val <= 100
1 <= n <= sz

代码:

/**
 * 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 fast = head;
    let slow = head;
   	while(n > 0){
        n--;
        fast = fast.next;
    }
    if(fast === null) {
        return head.next;
    }
    while(fast.next) {
        fast = fast.next;
        slow = slow.next;
    }
    slow.next = slow.next.next;
    return head;
};

思路:快慢指针,先让快指针先走n步,然后快慢指针同时走,当快指针走到尽头,慢指针将当前节点指针指向下下节点即可。

以上是关于算法-删除链表的倒数第 N 个结点的主要内容,如果未能解决你的问题,请参考以下文章

每天一道算法题(java数据结构与算法)——>删除链表的倒数第 N 个结点

算法-删除链表的倒数第 N 个结点

算法-删除链表的倒数第 N 个结点

算法-删除链表的倒数第 N 个结点

算法-删除链表的倒数第 N 个结点

每天一道算法题(java数据结构与算法)——>删除链表的倒数第 N 个结点