链接列表头C
Linked List Head C++
我正在为数据结构类制作一个简单的链接列表,并且很难理解头部指针应该如何工作。
我有
template <typename E>
class SSLL{
template<typename E>
struct Node {
E data;
Node* next;
};
public:
template <typename E>
SSLL();
void push_front(E element);
private:
Node<E> * head;
Node<E> * tail;
};
template <typename E>
SSLL<E>::SSLL() {
head = NULL;
tail = NULL;
}
template <typename E>
void SSLL<E>::push_front(E element) {
Node<E> * n = new Node<E>;
n->data = element;
n->next = head;
head = n;
if (!tail) {
tail = n;
}
}
但是,这不是使头成为列表中的第一个元素,而不是指向第一个元素的指针。
我尝试将push_front(e element)更改为此,但正在获取空指针错误。
template <typename E>
void SSLL<E>::push_front(E element) {
Node<E> * n = new Node<E>;
n->data = element;
n->next = head->next;
head->next = n;
if (!tail) {
tail->next = n;
}
}
我在网上发现的所有示例都有头= n,但是我仍然很难理解为什么它是那样而不是head-> next =n。
谢谢。
在大多数形式的链接列表中,头指针指向列表中的第一个节点或为null:
+---+ +---+ +--+
head --> | A | --> | B | --> |/0|
+---+ +---+ +--+
^
|
tail ----------------+
许多初学者将列表与节点混淆。节点是包含数据的对象。列表是节点的集合。
在头上推
在前面插入需要以下步骤:
- 使新节点指向头节点。
- 更改头节点以指向新节点。
1)使新节点指向头节点:
+---+
p_new -->| C |
+---+
|
V
+---+ +---+ +--+
head --> | A | --> | B | --> |/0|
+---+ +---+ +--+
2)将头指向新节点:
+---+
p_new -->| C |
head -->| |
+---+
|
V
+---+ +---+ +--+
| A | --> | B | --> |/0|
+---+ +---+ +--+
在C 中,这看起来像:
Node * p_node = new Node;
p_node->next = head; // Step 1.
head = p_node; // Step 2.
我们可以通过简单代码在C 中创建新的头:
ListNode* dummy = new ListNode(0);
dummy->next = head;
相关文章:
- Pybind11:将元组列表从Python传递到C++
- 从链接列表c++中删除一个项目
- 如何(从固定列表中)选择一个数字序列,该序列将与目标数字相加
- C++如何通过用户输入删除列表元素
- 读取文件的最后一行并输入到链接列表时出错
- 复制列表初始化的隐式转换的等级是多少
- LNK2038、MSVS2017 MAGMA的原因列表
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 没有为自己的结构调用列表推回方法
- 使用简单类型列表实现的指数编译时间.为什么
- 一对向量构造函数:初始值设定项列表与显式构造
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 通过for循环使用用户输入填充列表
- C++:如何使函数只返回作为列表一部分的字符串
- 概念中的cv限定符需要表达式参数列表
- 下面是我为检测链接列表中的循环而制作的代码
- 建议在运行时将带有类实例的列表从c++导入qml
- 如何维护资源管理器项目视图中当前可见的项目列表
- 在卡萨布兰卡形成编码参数的列表
- 在没有参数列表的情况下使用模板名称"Event"无效,模板问题