6-6 带头结点的单链表插入操作
时间: 2023-05-29 07:06:50 浏览: 341
带头结点的单链表插入操作包括以下步骤:
1. 创建一个新的节点,并将要插入的值赋给该节点的数据域;
2. 找到插入位置的前一个节点,可以从头结点开始遍历链表,直到找到插入位置的前一个节点为止;
3. 将新的节点插入到找到的前一个节点的后面,即将新节点的next指针指向前一个节点的next指针所指向的节点,然后将前一个节点的next指针指向新节点。
下面是带头结点的单链表插入操作的具体代码实现:
```c++
// 带头结点的单链表插入操作
void insert(ListNode *head, int val) {
ListNode *newNode = new ListNode(val);
ListNode *p = head;
while (p->next != NULL && p->next->val < val) {
p = p->next;
}
newNode->next = p->next;
p->next = newNode;
}
```
其中,ListNode是链表节点的定义,包括一个数据域val和一个指向下一个节点的指针next,代码中的head是链表的头结点。在插入操作中,先创建一个新的节点,并将要插入的值赋给该节点的数据域。然后从头结点开始遍历链表,找到插入位置的前一个节点,这里使用while循环遍历链表,直到找到插入位置的前一个节点为止。找到前一个节点后,将新的节点插入到该节点的后面,即将新节点的next指针指向前一个节点的next指针所指向的节点,然后将前一个节点的next指针指向新节点。最后,插入操作完成。
阅读全文