Node *p = list_reverse(head->next);
时间: 2024-02-22 08:00:13 浏览: 62
reverse-the-single-link-list.rar_single
这是一个链表反转的代码片段,假设链表的头节点为head,list_reverse()函数返回反转后的链表头节点的指针。具体实现可以参考以下代码:
```
struct Node {
int val;
Node *next;
Node(int x) : val(x), next(NULL) {}
};
Node* list_reverse(Node* head) {
Node *prev = NULL;
Node *cur = head;
while (cur) {
Node *next = cur->next;
cur->next = prev;
prev = cur;
cur = next;
}
return prev;
}
```
这段代码使用了三个指针,分别指向当前节点(cur)、当前节点的前驱节点(prev)和当前节点的后继节点(next),通过遍历整个链表,不断更新这三个指针的指向,最终实现了链表的反转。
阅读全文