双向链表删除节点时间复杂度_删除链表的节点(剑指offer第十七题)
刪除鏈表的節(jié)點(diǎn)
題目:給定單向鏈表的頭指針和一個(gè)要刪除的節(jié)點(diǎn)的值,定義一個(gè)函數(shù)刪除該節(jié)點(diǎn)。返回刪除后的鏈表的頭節(jié)點(diǎn)。
注意:此題對比原題有改動
示例 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é)點(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第十七题)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 为什么python不出结果_Python
- 下一篇: 输入参数的数目不足_机器学习算法—KME