給定乙個單鏈表和乙個指定節點,在o(1)內刪除指定節點。
功能測試:中間節點
特殊值測試:頭結點,尾節點
struct listnode
};bool deletelistnode(listnode* head,listnode* tobedelete)
else if(tobedelete->next==nullptr)
else
return f;
}
分析下,當指定節點是尾節點時,時間複雜度在o(n),而當指定節點非尾節點時,時間複雜度在(n-1)*o(1),綜合看,時間複雜度在(o(n)+o(1)*(n-1))/n,複雜度還是在o(1)。但是有個問題是不能確定tobedelete節點的存在,只能甩鍋給deletelistnode的呼叫函式了。 在O 1 時間內刪除鍊錶節點
題目 給定單向鍊錶的頭指標和乙個節點指標,定義乙個函式在o 1 的時間刪除該節點。struct listnode void deletenode listnode plisthead,listnode ptobedeleted 演算法思路 一般我們是從頭節點開始遍歷,知道找到要刪除的節點的前面乙個節...
在 O 1 時間內刪除鍊錶節點
解題思路 如果該節點不是尾節點,那麼可以直接將下乙個節點的值賦給該節點,然後令該節點指向下下個節點,再刪除下乙個節點,時間複雜度為 o 1 如果鍊錶只有乙個節點,那麼直接 否則,就需要先遍歷鍊錶,找到節點的前乙個節點,然後讓前乙個節點指向 null,時間複雜度為 o n 綜上,如果進行 n 次操作,...
在O 1 時間內刪除鍊錶節點
from acwing 28 time limit 1s memory limit 64mb problem description 給定單向鍊錶的乙個節點指標,定義乙個函式在o 1 時間刪除該結點。假設鍊錶一定存在,並且該節點一定不是尾節點。sample 輸入 鍊錶 1 4 6 8 刪掉節點 第2...