给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。 LeetCode题目链接。
输入:head = [1,2,3,4,5], n = 2
输出:[1,2,3,5]
输入:head = [1], n = 1
输出:[]
输入:head = [1,2], n = 1
输出:[1]
- 链表中结点的数目为 sz
- 1 <= sz <= 30
- 0 <= Node.val <= 100
- 1 <= n <= sz
- 你能尝试使用一趟扫描实现吗?
可以根据滑动窗口的思想来解决本题;
这题采用双指针,本题主要关键点为:
解决方法1(个人想法):
快慢指针第一次相遇:
看不懂解释的话,直接看算法图解比较容易理解点
时间复杂度:O(L),其中L是链表的长度。
空间复杂度:O(1)
红色部分代表快指针fast,灰色部分代表慢指针slow(注:本人不会做成流程动画,希望会的朋友可以私信我指点一二,说个软件名字也可以,谢谢)
每个代码块都写了注释,方便理解,代码还可以改进;
class Solution {public ListNode removeNthFromEnd(ListNode head, int n) {ListNode fast = head, slow = head;//先找出快指针的位置for(int i = 0; i < n; i++) fast = fast.next;while(true){if(fast == null)return head = head.next;else if(fast.next == null){slow.next = slow.next.next;return head;}//同时移动两个指针slow = slow.next;fast = fast.next;}}
}
提交结果:
以上就是今天要讲的内容,做题的时候发现寻找倒数第n个节点并删除,由于是单链表,所以需要找到倒数第n个节点的前驱结点才能删除,这样就可以把问题转变为寻找倒数第n个节点了,在利用滑动窗口的思路来移动快慢指针就可以了,所以就赶紧记录一下这时刻。