如何实现一个简单的链表或栈结构

在C++中实现一个简单的链表或栈结构,我们可以分别来看。首先,链表是一种线性数据结构,其中每个元素都包含数据本身以及指向列表中下一个元素的指针(对于双向链表,还会有指向前一个元素的指针)。而栈是一种后进先出(LIFO, Last In First Out)的数据结构,它只允许在栈顶进行添加(push)或删除(pop)元素的操作。

链表(单向链表)

下面是一个简单的单向链表的实现:

复制代码

cpp复制代码

|---|-----------------------------------------------|
| | #include <iostream> |
| | |
| | struct ListNode { |
| | int val; |
| | ListNode *next; |
| | ListNode(int x) : val(x), next(nullptr) {} |
| | }; |
| | |
| | class LinkedList { |
| | public: |
| | ListNode *head; |
| | |
| | LinkedList() : head(nullptr) {} |
| | |
| | // 在链表末尾添加元素 |
| | void append(int val) { |
| | ListNode* newNode = new ListNode(val); |
| | if (!head) { |
| | head = newNode; |
| | return; |
| | } |
| | ListNode* temp = head; |
| | while (temp->next) { |
| | temp = temp->next; |
| | } |
| | temp->next = newNode; |
| | } |
| | |
| | // 遍历链表并打印元素 |
| | void print() { |
| | ListNode* temp = head; |
| | while (temp) { |
| | std::cout << temp->val << " "; |
| | temp = temp->next; |
| | } |
| | std::cout << std::endl; |
| | } |
| | |
| | // 析构函数,释放链表占用的内存 |
| | ~LinkedList() { |
| | while (head) { |
| | ListNode* temp = head; |
| | head = head->next; |
| | delete temp; |
| | } |
| | } |
| | }; |
| | |
| | int main() { |
| | LinkedList list; |
| | list.append(1); |
| | list.append(2); |
| | list.append(3); |
| | list.print(); // 输出: 1 2 3 |
| | return 0; |
| | } |

栈的实现可以使用数组或链表。这里我们使用链表来实现栈,因为链表在动态扩展方面更加灵活:

复制代码

cpp复制代码

|---|-----------------------------------------------------------------------------------------------------------|
| | #include <iostream> |
| | |
| | struct StackNode { |
| | int val; |
| | StackNode *next; |
| | StackNode(int x) : val(x), next(nullptr) {} |
| | }; |
| | |
| | class Stack { |
| | private: |
| | StackNode *top; |
| | |
| | public: |
| | Stack() : top(nullptr) {} |
| | |
| | // 判断栈是否为空 |
| | bool isEmpty() { |
| | return top == nullptr; |
| | } |
| | |
| | // 向栈顶添加元素 |
| | void push(int val) { |
| | StackNode* newNode = new StackNode(val); |
| | newNode->next = top; |
| | top = newNode; |
| | } |
| | |
| | // 从栈顶删除元素 |
| | int pop() { |
| | if (isEmpty()) { |
| | throw std::runtime_error("pop from empty stack"); |
| | } |
| | StackNode* temp = top; |
| | int val = temp->val; |
| | top = top->next; |
| | delete temp; |
| | return val; |
| | } |
| | |
| | // 获取栈顶元素(不移除) |
| | int peek() { |
| | if (isEmpty()) { |
| | throw std::runtime_error("peek from empty stack"); |
| | } |
| | return top->val; |
| | } |
| | |
| | // 析构函数 |
| | ~Stack() { |
| | while (!isEmpty()) { |
| | pop(); |
| | } |
| | } |
| | }; |
| | |
| | int main() { |
| | Stack s; |
| | s.push(1); |
| | s.push(2); |
| | std::cout << "Top element is " << s.peek() << std::endl; // 输出: Top element is 2 |
| | s.pop(); |
| | std::cout << "After pop, top element is " << s.peek() << std::endl; // 输出: After pop, top element is 1 |
| | return 0; |
| | } |

在这两个示例中,我们定义了数据结构和基本操作,包括链表的添加、打印和析构,以及栈的push、pop、peek和析构。这些操作是这些数据结构的核心功能。

相关推荐
汀、人工智能8 小时前
[特殊字符] 第40课:二叉树最大深度
数据结构·算法·数据库架构·图论·bfs·二叉树最大深度
赫瑞9 小时前
数据结构中的排列组合 —— Java实现
java·开发语言·数据结构
大熊背9 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
yuannl1013 小时前
数据结构----队列的实现
数据结构
Mr_Xuhhh13 小时前
从ArrayList到LinkedList:理解链表,掌握Java集合的另一种选择
java·数据结构·链表
Ricardo-Yang15 小时前
SCNP语义分割边缘logits策略
数据结构·人工智能·python·深度学习·算法
soragui16 小时前
【Python】第 4 章:Python 数据结构实现
数据结构·windows·python
samroom16 小时前
【鸿蒙应用开发 Dev ECO Studio 5.0版本】从0到1!从无到有!最全!计算器------按钮动画、滑动退格、中缀表达式转后缀表达式、UI设计
数据结构·ui·华为·typescript·harmonyos·鸿蒙
算法鑫探17 小时前
10个数下标排序:最大值、最小值与平均值(下)
c语言·数据结构·算法·排序算法·新人首发
王老师青少年编程17 小时前
csp信奥赛c++之状压枚举
数据结构·c++·算法·csp·信奥赛·csp-s·状压枚举