Problem: 19. 删除链表的倒数第 N 个结点
文章目录
- 思路
- [💖 递归](#💖 递归)
- [💖 双指针](#💖 双指针)
思路
💖 递归
⏰ 时间复杂度: O ( n ) O(n) O(n)
🌎 空间复杂度: O ( n ) O(n) O(n)
java
class Solution {
// 递归
int cnt = 0;//计数器
public ListNode removeNthFromEnd(ListNode head, int n)
{
if (head == null)
return head;
head.next = removeNthFromEnd(head.next, n);
cnt++;//回溯时计数
if (cnt == n)//倒数第n个节点
return head.next;//把它的next返回
return head;
}
}
💖 双指针
⏰ 时间复杂度: O ( n ) O(n) O(n)
🌎 空间复杂度: O ( 1 ) O(1) O(1)
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(0, head);//哑兵节点,用于删除头结点
ListNode first = head;//先行指针
for (int i = 0; i < n; i++)
first = first.next;
ListNode cur = dummy;//先行指针和 cur 指针始终保持 n 的距离
while (first != null)// first 一直移动到尾节点
{
// 双指针一起移动
first = first.next;
cur = cur.next;
}
cur.next = cur.next.next;//cur后面的就是要删除的节点
return dummy.next;
}
}