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

在O(1)时间内删除链表节点(剑指offer_18.1)

时间:2019-12-29 14:45:50      阅读:76      评论:0      收藏:0      [点我收藏+]

标签:lse   直接   表示   val   user   时间   turn   else   head   

解题思路


  • 如果该节点不是尾结点,那么可以直接将下一个节点的值赋给该节点,然后该节点指向下下个节点,再删除下一个节点,时间复杂度为O(1)。

技术图片

  • 否则,就需要先遍历链表,找到节点的前一个节点,然后让前一个节点指向null,时间复杂度为O(N)。
    技术图片综上,如果进行N次操作,那么大约需要操作节点的次数为N-1+N = 2N - 1,其中N-1表示N-1个不是尾结点的每个节点以O(1)时间复杂度操作该节点的总次数,N表示1个尾结点以O(N)的时间复杂度操作节点的总次数。(2N-1)/N ~ 2,因此该算法的平均时间复杂度为O(1)。
public ListNode deleteNode(ListNode head,ListNode tobeDelete)
{
    if(head == null || tobeDelete == null)
    {
        return null;
    }
    if(tobeDelete.next != null)
    {
        //要删除的节点不是尾结点
        ListNode next = tobeDelete.next;
        tobeDelete.val = next.val;
        tobeDelete.next = next.next;
    }else{
        if(head == tobeDelete)
        {
            head = null;
        }
        else
        {
            ListNode cur = head;
            while(cur.next != null)
            {
                 cur = cur.next;
            }
            cur.next = null;
        }
    }
    return head;
}

在O(1)时间内删除链表节点(剑指offer_18.1)

标签:lse   直接   表示   val   user   时间   turn   else   head   

原文地址:https://www.cnblogs.com/ziytong/p/12114739.html

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