zoukankan      html  css  js  c++  java
  • 在O(1)时间内删除链表节点(剑指offer_18.1)

    解题思路


    • 如果该节点不是尾结点,那么可以直接将下一个节点的值赋给该节点,然后该节点指向下下个节点,再删除下一个节点,时间复杂度为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;
    }
  • 相关阅读:
    HCL AppScan Standard 9.0.3.13
    appscan 9.0.3.12 版本下载--补丁验证---win10 验证OK
    appscan 9.0.3.10 版本及补丁下载
    appscan 历史版本下载
    Python 批量文件下载
    广告URL
    Linux 修改hostname几种方式
    Kali系统 metasploit 使用教程
    Metasploit
    NIKTO
  • 原文地址:https://www.cnblogs.com/ziytong/p/12114739.html
Copyright © 2011-2022 走看看