算法-删除链表的倒数第 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 个结点的主要内容,如果未能解决你的问题,请参考以下文章