试编写算法将带头结点的单链表就地逆置
时间: 2023-04-26 21:02:57 浏览: 221
python单链表实现代码实例
算法步骤如下:
1. 定义三个指针:p、q、r,分别指向头结点、第一个结点和第二个结点。
2. 将第一个结点的 next 指针指向 NULL。
3. 将 q 指针指向第二个结点。
4. 将 r 指针指向第三个结点。
5. 依次将每个结点的 next 指针指向前一个结点,即将 q 的 next 指针指向 p,将 r 的 next 指针指向 q,以此类推。
6. 将头结点的 next 指针指向原链表的最后一个结点,即将 p 的 next 指针指向 NULL。
7. 返回头结点。
具体实现可以参考以下代码:
```
Node* reverseList(Node* head) {
if (head == NULL || head->next == NULL) {
return head;
}
Node *p = head, *q = head->next, *r = q->next;
p->next = NULL;
while (r != NULL) {
q->next = p;
p = q;
q = r;
r = r->next;
}
q->next = p;
head->next = q;
return head;
}
```
阅读全文