LCR 021. 删除链表的倒数第N个结点(中等)
1,问题描述
难度:中等
给定一个链表,删除链表的倒数第 n
个结点,并且返回链表的头结点。
示例 1:
1 | 输入:head = [1,2,3,4,5], n = 2 |
示例 2:
1 | 输入:head = [1], n = 1 |
示例 3:
1 | 输入:head = [1,2], n = 1 |
提示:
- 链表中结点的数目为
sz
1 <= sz <= 30
0 <= Node.val <= 100
1 <= n <= sz
**进阶:**能尝试使用一趟扫描实现吗?
注意:本题与主站 19 题相同: https://leetcode-cn.com/problems/remove-nth-node-from-end-of-list/
2,初步思考
滑动窗的概念进行解决
为了解决,head头将被替换的情况,直接给他新加一个头,
3,代码处理
1 | public static ListNode removeNthFromEnd(ListNode head, int n) { |