给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。
示例 1:
 
输入:head = [1,2,3,4,5], n = 2
 输出:[1,2,3,5]
示例 2:
 输入:head = [1], n = 1
 输出:[]
示例 3:
 输入:head = [1,2], n = 1
 输出:[1]
提示:
 链表中结点的数目为 sz
 1 <= sz <= 30
 0 <= Node.val <= 100
 1 <= n <= sz
来源:力扣(LeetCode)
 链接:https://leetcode.cn/problems/linked-list-cycle
 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode dummy = new ListNode(-1);
        dummy.next = head;
        ListNode fast = dummy, slow = dummy;
        for(int i = 0; i <= n; i++){
            fast = fast.next;
        }
        while(fast != null){
            fast = fast.next;
            slow = slow.next;
        }
        slow.next = slow.next.next;
        return dummy.next;
    }
}













![[Verilog]有限状态机设计举例](https://img-blog.csdnimg.cn/img_convert/261f6d88fe0ae4ce76f203bb7dda4610.png)





