//双向链表中的节点元素
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