删除双向链表中的节点需要考虑以下几种情况:
删除头节点:如果要删除的节点是头节点,需要将头节点指针指向下一个节点,并释放原来的头节点内存。
删除尾节点:如果要删除的节点是尾节点,需要将尾节点的前一个节点的next指针指向NULL,并释放原来的尾节点内存。
删除中间节点:如果要删除的节点是中间节点,需要将该节点的前一个节点的next指针指向该节点的下一个节点,同时将该节点的下一个节点的prev指针指向该节点的前一个节点,并释放原来的节点内存。
下面是一个示例代码,用来删除双向链表中的某个节点:
#include <stdio.h>
#include <stdlib.h>
typedef struct Node {
int data;
struct Node* prev;
struct Node* next;
} Node;
Node* deleteNode(Node* head, Node* node) {
if (head == NULL || node == NULL) {
return head;
}
if (head == node) {
head = node->next;
}
if (node->prev != NULL) {
node->prev->next = node->next;
}
if (node->next != NULL) {
node->next->prev = node->prev;
}
free(node);
return head;
}
int main() {
Node* head = NULL;
Node* node1 = (Node*)malloc(sizeof(Node));
Node* node2 = (Node*)malloc(sizeof(Node));
head = node1;
node1->data = 1;
node1->prev = NULL;
node1->next = node2;
node2->data = 2;
node2->prev = node1;
node2->next = NULL;
head = deleteNode(head, node1);
Node* current = head;
while (current != NULL) {
printf("%d\n", current->data);
current = current->next;
}
return 0;
}
在上面的示例代码中,deleteNode函数用来删除双向链表中的某个节点,main函数创建了一个双向链表并删除了其中的一个节点。