日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

双向链表删除节点时间复杂度_删除链表的节点(剑指offer第十七题)

發布時間:2025/3/21 编程问答 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 双向链表删除节点时间复杂度_删除链表的节点(剑指offer第十七题) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

刪除鏈表的節點

題目:給定單向鏈表的頭指針和一個要刪除的節點的值,定義一個函數刪除該節點。返回刪除后的鏈表的頭節點。

注意:此題對比原題有改動

示例 1:
輸入: head = [4,5,1,9], val = 5
輸出: [4,1,9]
解釋: 給定你鏈表中值為 5 的第二個節點,那么在調用了你的函數之后,該鏈表應變為 4 -> 1 -> 9.

示例 2:
輸入: head = [4,5,1,9], val = 1
輸出: [4,5,9]
解釋: 給定你鏈表中值為 1 的第三個節點,那么在調用了你的函數之后,該鏈表應變為 4 -> 5 -> 9.

說明:
題目保證鏈表中節點的值互不相同
若使用 C 或 C++ 語言,你不需要 free 或 delete 被刪除的節點

解題思路

雙指針法:分兩步解此題。首先我們遍歷鏈表定位到要刪除的節點。然后通過改變指針指向來刪除元素。

算法執行過程:

  • 判斷邊界條件:當應刪除頭節點 head 時,直接返回 head.next 即可。

  • 初始化雙指針:r =NULL , p = head->next 。

  • 定位節點:當 p 為空 或 p 節點值等于 val 時跳出。

  • 保存當前節點索引,即 r = p 。遍歷下一節點,即 p = p->next.

  • 刪除節點:若 p 指向某節點,則執行 r->next =r->next->next 。(若 p 指向NULL ,代表鏈表中不包含值為 val 的節點。)

  • 返回值:返回鏈表頭部節點 head 即可。

  • 代碼展示

    代碼如下:

    /**
    * Definition for singly-linked list.
    * struct ListNode {
    * int val;
    * ListNode *next;
    * ListNode(int x) : val(x), next(NULL) {}
    * };
    */
    class Solution {
    public:
    ListNode* deleteNode(ListNode* head, int val) {
    ListNode *p=head,*r=NULL;
    if(head==NULL) return head;
    if(head->val==val) return head->next;
    while(p && p->val!=val)
    {
    r=p;
    p=p->next;
    }
    r->next=r->next->next;
    return head;
    }
    };
    執行用時:4 ms, 在所有 C++ 提交中擊敗了99.85%的用戶
    內存消耗:8.2 MB, 在所有 C++ 提交中擊敗了98.65%的用戶

    總結

    以上是生活随笔為你收集整理的双向链表删除节点时间复杂度_删除链表的节点(剑指offer第十七题)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。