//双向链表中的节点元素 struct Node { int data; Node *next; // 指向下一个节点 Node *prev; // 指向前一个节点 };
// 给定链表的头指针(head)以及一个整数,插入一个新的节点至链表的头部 // 之所以传入双指针,因为函数中需要修改链表 void push(Node** head, int newData) { //1. 分配新节点内存 Node* newNode = new Node; //2. 赋值 newNode->data = newData; //3. 将原始头节点做为新节点的后向指针,而前向指针置为NULL newNode->next = (*head); newNode->prev = NULL; //4. 将原始头节点的前向指针置为新的节点 if ((*head) != NULL) (*head)->prev = newNode; //5. 将头指针置为新的节点 (*head) = newNode; }上面的前4个步骤,与单链表中插入节点至头部的操作步骤是一样的。只是这里新增了一个步骤,就是改变头部的前向指针。
//插入一个节点至指定节点的后面 void insertAfter(Node* prevNode, int newData) { // 1. 检查指定节点是否为NULL if (prevNode == NULL) { std::cout<<"the given previous node cannot be NULL"; return; } // 2. 分配新节点内存 Node* newNode = new Node; // 3. 赋值 newNode->data = newData; // 4. 将指定节点的后向指针,做为新节点的后向指针 newNode->next = prevNode->next; // 5. 将新节点做为指定节点的后向指针 prevNode->next = newNode; // 6. 将指定节点做为新节点的前向指针 newNode->prev = prevNode; // 7. 调整新节点的后续节点的前向指针 if (newNode->next != NULL) newNode->next->prev = newNode; }上面的前5个步骤,与单链表中插入节点至指定节点的后面的操作步骤是一样的。只是这里新增了两个步骤。即新节点的前向指针,以及新节点的后续节点的前向指针。
// 给定链表的头指针(head)以及一个整数,插入一个新的节点至链表的尾部 void append(Node** head, int newData) { // 1. 分配新节点内存 Node *newNode = new Node; Node *last = *head; //链表的尾部指针,用于step5 // 2. 赋值 newNode->data = newData; // 3. 新节点将成为尾节点,所以后向指针为NULL newNode->next = NULL; // 4. 如果是空链表,则直接将新节点设置为头节点 if (*head == NULL) { newNode->prev = NULL; *head = newNode; return; } // 5. 如果不是空链表,则遍历链表,获取尾节点 while (last->next != NULL) last = last->next; // 6. 修改尾节点的后向指针为新节点 last->next = newNode; // 7. 修改新节点的前向指针为原始尾节点 newNode->prev = last; return; }上面的前7个步骤,与单链表中进行相应操作的前6个步骤相同。新增的1个步骤是修改新节点的前向指针。
void insertBefore(Node* nextNode, int newData) { // 1. 检查指定节点是否为NULL if (nextNode == NULL) { printf("the given previous node cannot be NULL"); return; } // 2. 分配新节点内存 Node* newNode = new Node; // 3. 赋值 newNode->data = newData; // 4. 将指定节点的前向指针,做为新节点的前向指针 newNode->prev = nextNode->prev; // 5. 将新节点做为指定节点的前向指针 nextNode->prev = newNode; // 6. 将指定节点做为新节点的后向指针 newNode->next = nextNode; // 7. 调整新节点的前面节点的后向指针 if (newNode->prev != NULL) newNode->prev->next = newNode; }
#include <iostream> struct Node { int data; Node *next; // 指向下一个节点 Node *prev; // 指向前一个节点 }; // 给定链表的头指针(head)以及一个整数,插入一个新的节点至链表的头部 // 之所以传入双指针,因为函数中需要修改链表 void push(Node** head, int newData) { //1. 分配新节点内存 Node* newNode = new Node; //2. 赋值 newNode->data = newData; //3. 将原始头节点做为新节点的后向指针,而前向指针置为NULL newNode->next = (*head); newNode->prev = NULL; //4. 将原始头节点的前向指针置为新的节点 if ((*head) != NULL) (*head)->prev = newNode; //5. 将头指针置为新的节点 (*head) = newNode; } //插入一个节点至指定节点的后面 void insertAfter(Node* prevNode, int newData) { // 1. 检查指定节点是否为NULL if (prevNode == NULL) { std::cout<<"the given previous node cannot be NULL"; return; } // 2. 分配新节点内存 Node* newNode = new Node; // 3. 赋值 newNode->data = newData; // 4. 将指定节点的后向指针,做为新节点的后向指针 newNode->next = prevNode->next; // 5. 将新节点做为指定节点的后向指针 prevNode->next = newNode; // 6. 将指定节点做为新节点的前向指针 newNode->prev = prevNode; // 7. 调整新节点的后续节点的前向指针 if (newNode->next != NULL) newNode->next->prev = newNode; } // 给定链表的头指针(head)以及一个整数,插入一个新的节点至链表的尾部 void append(Node** head, int newData) { // 1. 分配新节点内存 Node *newNode = new Node; Node *last = *head; //链表的尾部指针,用于step5 // 2. 赋值 newNode->data = newData; // 3. 新节点将成为尾节点,所以后向指针为NULL newNode->next = NULL; // 4. 如果是空链表,则直接将新节点设置为头节点 if (*head == NULL) { newNode->prev = NULL; *head = newNode; return; } // 5. 如果不是空链表,则遍历链表,获取尾节点 while (last->next != NULL) last = last->next; // 6. 修改尾节点的后向指针为新节点 last->next = newNode; // 7. 修改新节点的前向指针为原始尾节点 newNode->prev = last; return; } //插入一个节点至指定节点的前面 void insertBefore(Node* nextNode, int newData) { // 1. 检查指定节点是否为NULL if (nextNode == NULL) { printf("the given previous node cannot be NULL"); return; } // 2. 分配新节点内存 Node* newNode = new Node; // 3. 赋值 newNode->data = newData; // 4. 将指定节点的前向指针,做为新节点的前向指针 newNode->prev = nextNode->prev; // 5. 将新节点做为指定节点的前向指针 nextNode->prev = newNode; // 6. 将指定节点做为新节点的后向指针 newNode->next = nextNode; // 7. 调整新节点的前面节点的后向指针 if (newNode->prev != NULL) newNode->prev->next = newNode; } void printList(Node *head) { Node *last = NULL; std::cout<<"\nTraversal in forward direction \n"; while (head != NULL) { std::cout<<" "<<head->data<<" "; last = head; head = head->next; } std::cout<<"\nTraversal in reverse direction \n"; while (last != NULL) { std::cout << " " << last->data << " "; last = last->prev; } std::cout << std::endl; } int main() { //初始化为空链表 Node* head = NULL; // 插入节点6. 链表变为:6->NULL append(&head, 6); // 插入节点7,链表变为:7->6->NULL push(&head, 7); // 头部插入节点1,链表变为:1->7->6->NULL push(&head, 1); // 尾部插入节点4,链表变为:1->7->6->4->NULL append(&head, 4); // 在节点7后面插入节点8,链表变为:1->7->8->6->4->NULL insertAfter(head->next, 8); // 节点8之前插入节点9,链表变为:1->7->9->8->6->4->NULL insertBefore(head->next->next, 9); std::cout<<"Created DLL is: "; printList(head); return 0; }输出:
原文:http://blog.csdn.net/shltsh/article/details/46485679