LeetCode19 删除链表的倒数第N个节点
题目描述
给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。
样例
给定一个链表: 1->2->3->4->5, 和 n = 2.
当删除了倒数第二个节点后,链表变为 1->2->3->5.
算法分析
链表题
题目要求是删除倒数的第n
个节点
- 可能删除头节点,==> 技巧: 建立虚拟头节点
dummy.next = head
- 删除一个节点,要找到这个节点的上一个点即可 ==> 核心就是找到第k个点的前一个点
- 用两个指针,
f
和s
,先确保f
与s
距离为n
,这样,f
指向倒数第一个节点时候,s
指向倒数第n
个节点 s.next = s.next.next
时间复杂度
$O(n)$
Java代码
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode() {}
* ListNode(int val) { this.val = val; }
* ListNode(int val, ListNode next) { this.val = val; this.next = next; }
* }
*/
class Solution {
public ListNode removeNthFromEnd(ListNode head, int n) {
ListNode dummy = new ListNode(-1);
dummy.next = head;
ListNode first = dummy;
ListNode second = dummy;
for(int i = 0; i < n; i++){
first = first.next;
}
while(first.next!=null){
first = first.next;
second = second.next;
}
//此时second指向倒数第n+1个节点
second.next = second.next.next;
return dummy.next;
}
}