- 题目:
请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。
现有一个链表 – head = [4,5,1,9],它可以表示为:
4 -> 5 -> 1 -> 9
示例 1:
输入: head = [4,5,1,9], node = 5
输出: [4,1,9]
解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.
- 解题思路一:
将删除节点换到最后一个节点,在删除最后一个节点
void deleteNode(ListNode* node) {
ListNode * last = node->next;
while(last->next != nullptr)
{
node->val = last->val;
node = last;
last = last->next;
}
node->val = last->val;
node->next =nullptr;
}
时间复杂度:O(n)
空间复杂度:O(1)
- 解题思路二
将删除节点换到相邻节点,删除相邻节点
void deleteNode(ListNode* node) {
ListNode * last = node->next;
node->val = last->val;
node->next = last->next;
}
时间复杂度:O(1)
空间复杂度:O(1)