删除链表的倒数第n个结点

Posted wangAQS

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了删除链表的倒数第n个结点相关的知识,希望对你有一定的参考价值。

给定一个链表,删除链表的倒数第 个节点,并且返回链表的头结点。

class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {

        //链表长度为5(len),倒数第2(n)个节点,正数第4(len - n + 1)个节点
        //考虑删除第一个节点的特殊情况,则添加一个头结点。
ListNode h = new ListNode(0); h.next = head; int len = 0; while(head != null){ len++; head = head.next; } int count = len - n + 1; ListNode cur = h; int i = 1; while(i < count){ cur = cur.next; i++; } cur.next = cur.next.next; return h.next; } }

上述解法是通过两次遍历链表删除了结点,如果要求只能一次遍历,则解法如下。

class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {

        //要删除的节点是倒数第n个,通过快慢指针的方法
        ListNode h = new ListNode(0);
        h.next = head;
        //已有前提保证n是有效的
        //快指针先走n个位置
        ListNode low = h, high = h;
        int i = 0;
        while(i < n){
            high = high.next;
            i++;
        }
        //此时快慢指针再一起出发
        while(high.next != null){
            low = low.next;
            high = high.next;
        }
        low.next = low.next.next;
        return h.next;

    }
}

 

以上是关于删除链表的倒数第n个结点的主要内容,如果未能解决你的问题,请参考以下文章

19链表-删除链表的倒数第N个结点

给定一个链表,删除链表的倒数第 n 个节点(已知该结点存在),并且返回链表的头结点。

删除链表的倒数第n个结点

LeetCode 19. 删除链表的倒数第 N 个结点

删除链表的倒数第 N 个结点

LeetCode-019-删除链表的倒数第 N 个结点