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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

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

刪除鏈表的節(jié)點(diǎn)

題目:給定單向鏈表的頭指針和一個(gè)要?jiǎng)h除的節(jié)點(diǎn)的值,定義一個(gè)函數(shù)刪除該節(jié)點(diǎn)。返回刪除后的鏈表的頭節(jié)點(diǎn)。

注意:此題對(duì)比原題有改動(dòng)

示例 1:
輸入: head = [4,5,1,9], val = 5
輸出: [4,1,9]
解釋: 給定你鏈表中值為 5 的第二個(gè)節(jié)點(diǎn),那么在調(diào)用了你的函數(shù)之后,該鏈表應(yīng)變?yōu)?4 -> 1 -> 9.

示例 2:
輸入: head = [4,5,1,9], val = 1
輸出: [4,5,9]
解釋: 給定你鏈表中值為 1 的第三個(gè)節(jié)點(diǎn),那么在調(diào)用了你的函數(shù)之后,該鏈表應(yīng)變?yōu)?4 -> 5 -> 9.

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

解題思路

雙指針法:分兩步解此題。首先我們遍歷鏈表定位到要?jiǎng)h除的節(jié)點(diǎn)。然后通過改變指針指向來刪除元素。

算法執(zhí)行過程:

  • 判斷邊界條件:當(dāng)應(yīng)刪除頭節(jié)點(diǎn) head 時(shí),直接返回 head.next 即可。

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

  • 定位節(jié)點(diǎn):當(dāng) p 為空 或 p 節(jié)點(diǎn)值等于 val 時(shí)跳出。

  • 保存當(dāng)前節(jié)點(diǎn)索引,即 r = p 。遍歷下一節(jié)點(diǎn),即 p = p->next.

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

  • 返回值:返回鏈表頭部節(jié)點(diǎn) 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;
    }
    };
    執(zhí)行用時(shí):4 ms, 在所有 C++ 提交中擊敗了99.85%的用戶
    內(nèi)存消耗:8.2 MB, 在所有 C++ 提交中擊敗了98.65%的用戶

    總結(jié)

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

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。