双向链表通过节点的前驱和后继指针实现双向访问,其基本结构包含数据域和两个指针域,可高效支持正向与反向遍历及两端操作。

在C++中实现双向链表,首先要定义节点结构。每个节点包含数据域和两个指针:一个指向后继节点,一个指向前驱节点。
以下是一个简单的双向链表节点的定义:
立即学习“C++免费学习笔记(深入)”;
struct ListNode {
int data; // 数据域,这里以int为例
ListNode* prev; // 指向前一个节点
ListNode* next; // 指向后一个节点
<pre class='brush:php;toolbar:false;'>// 构造函数,方便初始化
ListNode(int value) : data(value), prev(nullptr), next(nullptr) {}};
有了节点结构后,可以定义一个链表类来管理节点的操作,如插入、删除、遍历等。
封装一个 DoublyLinkedList 类,包含头指针和尾指针,便于从两端操作。
立即学习“C++免费学习笔记(深入)”;
class DoublyLinkedList {
public:
ListNode* head;
ListNode* tail;
<pre class='brush:php;toolbar:false;'>DoublyLinkedList() : head(nullptr), tail(nullptr) {}
// 添加节点到链表末尾
void append(int value) {
ListNode* newNode = new ListNode(value);
if (!head) {
head = tail = newNode;
} else {
newNode->prev = tail;
tail->next = newNode;
tail = newNode;
}
}
// 释放所有节点内存
~DoublyLinkedList() {
ListNode* curr = head;
while (curr) {
ListNode* temp = curr;
curr = curr->next;
delete temp;
}
}};
由于双向链表有前后指针,可以从头到尾或从尾到头遍历。
正向遍历(从 head 到 tail):
立即学习“C++免费学习笔记(深入)”;
void printForward() {
ListNode* curr = head;
while (curr) {
std::cout << curr->data << " ";
curr = curr->next;
}
std::cout << std::endl;
}
反向遍历(从 tail 到 head):
立即学习“C++免费学习笔记(深入)”;
void printReverse() {
ListNode* curr = tail;
while (curr) {
std::cout << curr->data << " ";
curr = curr->prev;
}
std::cout << std::endl;
}
这样就能灵活地双向访问数据,适用于需要频繁前后移动的场景。
下面是一个完整的使用例子:
立即学习“C++免费学习笔记(深入)”;
#include <iostream>
using namespace std;
<p>int main() {
DoublyLinkedList dll;
dll.append(10);
dll.append(20);
dll.append(30);</p><pre class='brush:php;toolbar:false;'>cout << "正向遍历: ";
dll.printForward(); // 输出: 10 20 30
cout << "反向遍历: ";
dll.printReverse(); // 输出: 30 20 10
return 0;}
这个实现涵盖了双向链表的基本结构、节点插入和双向遍历功能。可以根据需要扩展插入到指定位置、删除节点、查找元素等功能。
基本上就这些,结构清晰,操作直观,适合学习数据结构的基础实现。
以上就是c++++如何实现一个双向链表_c++链表数据结构的定义与遍历实现的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号