一、题目描述
给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。
二、题目详解
给定一个链表: 1->2->3->4->5, 和 n = 2.
当删除了倒数第二个节点后,链表变为 1->2->3->5.
说明:给定的 n 保证是有效的。
子问题
:找到倒数第n个结点的前驱
1.有两个引用,第一个引用指向首节点,然后走n步
2.第二个结点指向首节点,此时两结点之间隔了n-1个结点,保持这样的距离,共同向后移动
3.当第一个引用到达尾节点时,第二个引用离尾节点有n-1个结点,
4.此时第二个结点为倒数第n+1个结点,即倒数第n个结点的前驱
特殊情况
:
1.链表只有一个结点或者为空链表,直接返回空即可;
2.链表的长度刚好等于n,即删除首节点,第一个引用从头结点开始移动n步后,
第一个引用移动到了尾节点的下一个,即此时第一个引用为空,
出现第一个在移动n步后为空的情况时,说明要删除的是首节点,直接将首节点定为首节点的下一个即可
三、思路分析
快慢指针,快走n步,快慢一起走。
四、详解代码
package com.z