| 学习路线指引(点击解锁) | 知识定位 | 人群定位 |
|---|---|---|
| 🧡 Python实战微信订餐小程序 🧡 | 进阶级 | 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。 |
| 💛Python量化交易实战💛 | 入门级 | 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统 |
给定一个链表,删除链表的倒数第 n 个节点并返回链表的头指针。要求:空间复杂度 O(1)O(1)O(1),时间复杂度 O(n)O(n)O(n)
如果倒数第 k 个结点刚好是头结点,那头结点需要特殊处理。为了各个结点能等同操作,设置一个虚拟头结点。
寻找倒数第 k 个结点常使用“快慢双指针”来实现。
java
public class Solution {
static class ListNode {
int val;
ListNode next = null;
}
public ListNode removeNthFromEnd (ListNode head, int k) {
// 1. 添加一个虚拟头结点
ListNode dummy = new ListNode(-1);
dummy.next = head;
// 2. 使用快慢指针找到倒数第 k+1 个结点
ListNode prev = getNode(dummy, n);
// 3. 删除 倒数 第 k 个结点
prev.next = prev.next.next;
return dummy.next;
}