题目:
给定一个链表,删除链表的倒数第 n 个节点并返回链表的头指针。
例如,给出的链表为: 1→2→3→4→5, n=2.
删除了链表的倒数第 n个节点之后,链表变为1→2→3→5.
数据范围: 链表长度 0≤n≤1000,链表中任意节点的值满足 0≤val≤100。
要求:空间复杂度 O(1),时间复杂度 O(n)。
备注:题目保证 n一定是有效的。
示例1
输入:{1,2},2
返回值:{2}
思路:
与上一题类似,采用快慢指针法,不同的是,此题的slow和fast两个快慢指针都是从dummy虚拟头节点开始向后走,这样可以确保当fast指向null时,slow恰好指向待删除节点的前一个节点,方便删除节点。
代码:
import java.util.*;
/*
* public class ListNode {
* int val;
* ListNode next = null;
* }
*/
public class Solution {
/**
*
* @param head ListNode类
* @param n int整型
* @return ListNode类
*/
public ListNode removeNthFromEnd (ListNode head, int n) {
// write code here
//判断边界条件
if(head == null){
return null;
}
ListNode dummy = new ListNode(-1);
dummy.next = head;
//快慢指针法先找出链表倒数第n个节点
ListNode slow = dummy, fast = dummy;
//先让fast走n步
for(int i = 0; i < n + 1; i++){
if(fast == null){
return head;
}
fast = fast.next;
}
while(fast != null){
slow = slow.next;
fast = fast.next;
}
//此时slow就指向了待删除节点的前一个节点
slow.next = slow.next.next;
return dummy.next;
}
}