码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2019-11-23 23:31:32      阅读:82      评论:0      收藏:0      [点我收藏+]

标签:一个   返回   指针   remove   next   方法   链表删除   new   bsp   

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

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个结点

标签:一个   返回   指针   remove   next   方法   链表删除   new   bsp   

原文地址:https://www.cnblogs.com/Aug-20/p/11920736.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!