双向链表删除节点时间复杂度_删除链表的节点(剑指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第十七题)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 为什么python不出结果_Python
- 下一篇: react ui框架 移动端_你必须要知